



ISO9001:2015 质量管理体系受控文件

## TX8W7010 用户手册



珠海泰芯半导体有限公司

Zhuhai Taixin Semiconductor Co., Ltd

珠海市高新区港湾一号科创园港 11 栋 3 楼

|      |            |               |      |                     |
|------|------------|---------------|------|---------------------|
| 保密等级 | A          | TX8W7010 用户手册 | 文件编号 | TX-WI-TX8W7010-RD02 |
| 发行日期 | 2023-02-03 |               | 文件版本 | V1.7                |

## 修订记录

| 日期         | 版本   | 描述                                                                                                                                           | 修订人 |
|------------|------|----------------------------------------------------------------------------------------------------------------------------------------------|-----|
| 2023-02-03 | V1.7 | 1、解决部分设备打开阅读时，出现乱码问题                                                                                                                         | YLC |
| 2023-01-09 | V1.6 | 1、修改 CMP_STA[5:2]的寄存器错误描述。补充对 CMP_STA[7:6]的描述。修改 CMPO_CON4[4], CMPO_CON4[6], CMP1_CON4[4], CMP1_CON4[6]的描述使之更容易理解。修改低功耗管理章节的关于进入 IDLE 模式的描述； | YLC |
| 2022-08-10 | V1.5 | 1、修改 ADC 模块的分频比描述                                                                                                                            | TX  |
| 2022-03-18 | V1.4 | 1、修改 AIP_CON1 寄存器第 1 和 0 位的错误描述。修改模拟比较器 CON4 的 N 管 P 管开关功能的描述。                                                                               | TX  |
| 2022-03-10 | V1.3 | 1、完善 RF 收发器 2.4G 模式用户使用说明。                                                                                                                   | TX  |
| 2022-03-09 | V1.2 | 1、完善 RF 收发器 2.4G 模式用户使用说明。                                                                                                                   | TX  |
| 2022-03-03 | V1.1 | 1、补充 RF 收发器用户寄存器使用说明。                                                                                                                        | TX  |
| 2022-03-03 | V1.0 | 1、初始版本                                                                                                                                       | TX  |



珠海泰芯半导体有限公司  
Zhuhai Taixin Semiconductor Co., Ltd

珠海市高新区港湾一号科创园港 11 栋 3 楼

|      |            |               |      |                     |
|------|------------|---------------|------|---------------------|
| 保密等级 | A          | TX8W7010 用户手册 | 文件编号 | TX-WI-TX8W7010-RD02 |
| 发行日期 | 2022-08-10 |               | 文件版本 | V1.5                |

## 目录

|                                  |    |
|----------------------------------|----|
| TX8W7010 用户手册 .....              | 1  |
| 1. 产品概述 .....                    | 1  |
| 1. 1. 说明 .....                   | 1  |
| 1. 2. 特性 .....                   | 2  |
| 1. 3. 引脚分配 .....                 | 5  |
| 1. 4. 封装信息 .....                 | 5  |
| 1. 5. 封装尺寸图 .....                | 5  |
| 1. 6. 引脚说明 .....                 | 6  |
| 2. 中央处理器 .....                   | 8  |
| 2. 1. 累加器（ACC） .....             | 8  |
| 2. 2. 寄存器（B） .....               | 9  |
| 2. 3. 堆栈指针寄存器（SP） .....          | 9  |
| 2. 4. 堆栈指针寄存器（SPH） .....         | 9  |
| 2. 5. 数据指针寄存器（DPTR0/DPTR1） ..... | 10 |
| 2. 6. 数据指针控制寄存器（DPCFG） .....     | 10 |
| 2. 7. 程序状态寄存器（PSW） .....         | 12 |
| 2. 8. 程序计数器（PC） .....            | 12 |
| 3. 存储器 .....                     | 13 |
| 3. 1. 程序存储器 .....                | 13 |
| 3. 2. XDATA .....                | 14 |
| 3. 3. IDATA .....                | 15 |
| 3. 4. SFR 空间 .....               | 17 |
| 4. 系统时钟 .....                    | 18 |
| 4. 1. 时钟系统概述 .....               | 18 |
| 4. 2. 时钟系统主要功能 .....             | 18 |
| 4. 3. 时钟系统框图 .....               | 19 |
| 4. 4. 系统振荡器 .....                | 20 |
| 4. 4. 1. 内部低速 RC 振荡器 .....       | 20 |
| 4. 4. 2. 内部高速 RC 振荡器 .....       | 20 |



珠海泰芯半导体有限公司  
Zhuhai Taixin Semiconductor Co., Ltd

珠海市高新区港湾一号科创园港 11 栋 3 楼

|      |            |               |      |                     |
|------|------------|---------------|------|---------------------|
| 保密等级 | A          | TX8W7010 用户手册 | 文件编号 | TX-WI-TX8W7010-RD02 |
| 发行日期 | 2022-08-10 |               | 文件版本 | V1.5                |

|                            |    |
|----------------------------|----|
| 4. 4. 3. 外部低速晶体振荡器 .....   | 20 |
| 5. 复位系统 .....              | 21 |
| 5. 1. 上电复位 .....           | 21 |
| 5. 2. 掉电复位掉 .....          | 21 |
| 5. 3. 看门狗复位 .....          | 21 |
| 5. 3. 1. 控制寄存器列表 .....     | 21 |
| 5. 3. 2. 寄存器详细说明 .....     | 22 |
| 5. 4. 低电检测复位 .....         | 24 |
| 5. 4. 1. 控制寄存器列表 .....     | 24 |
| 5. 4. 2. 寄存器详细说明 .....     | 24 |
| 6. 低功耗管理 .....             | 27 |
| 6. 1. Idle Mode 及唤醒 .....  | 28 |
| 6. 2. Stop Mode 及唤醒 .....  | 28 |
| 6. 3. Sleep Mode 及唤醒 ..... | 28 |
| 6. 4. 低功耗唤醒单元结构图 .....     | 28 |
| 7. 系统控制模块 .....            | 29 |
| 7. 1. 功能概述 .....           | 29 |
| 7. 2. 寄存器列表 .....          | 29 |
| 7. 3. 寄存器详细说明 .....        | 31 |
| 7. 3. 1. SYS_CON0 .....    | 31 |
| 7. 3. 2. SYS_CON1 .....    | 31 |
| 7. 3. 3. SYS_CON2 .....    | 32 |
| 7. 3. 4. SYS_CON3 .....    | 33 |
| 7. 3. 5. SYS_CON4 .....    | 34 |
| 7. 3. 6. SYS_CON5 .....    | 35 |
| 7. 3. 7. CLK_CON0 .....    | 36 |
| 7. 3. 8. CLK_CON1 .....    | 37 |
| 7. 3. 9. CLK_CON2 .....    | 38 |
| 7. 3. 10. CLK_CON3 .....   | 38 |
| 7. 3. 11. CLK_CON4 .....   | 39 |
| 7. 3. 12. CLK_CON5 .....   | 40 |
| 7. 3. 13. CLK_CON6 .....   | 40 |
| 7. 3. 14. AIP_CON0 .....   | 41 |
| 7. 3. 15. AIP_CON1 .....   | 41 |
| 7. 3. 16. AIP_CON2 .....   | 42 |
| 7. 3. 17. AIP_CON3 .....   | 42 |



珠海泰芯半导体有限公司  
Zhuhai Taixin Semiconductor Co., Ltd

珠海市高新区港湾一号科创园港 11 栋 3 楼

|      |            |               |      |                     |
|------|------------|---------------|------|---------------------|
| 保密等级 | A          | TX8W7010 用户手册 | 文件编号 | TX-WI-TX8W7010-RD02 |
| 发行日期 | 2022-08-10 |               | 文件版本 | V1.5                |

|                           |    |
|---------------------------|----|
| 7. 3. 18. AIP_CON4 .....  | 42 |
| 7. 3. 19. IO_MAP .....    | 42 |
| 7. 3. 20. IO_MAP1 .....   | 43 |
| 7. 3. 21. WKUP_CON0 ..... | 44 |
| 7. 3. 22. WKUP_PND .....  | 45 |
| 7. 3. 23. LP_CON .....    | 46 |
| 7. 3. 24. SYS_PND .....   | 47 |
| 8. 中断系统 .....             | 47 |
| 8. 1. 中断概述 .....          | 47 |
| 8. 2. 结构框图 .....          | 48 |
| 8. 3. 中断向量表 .....         | 49 |
| 8. 4. 寄存器列表 .....         | 49 |
| 8. 5. 寄存器详细说明 .....       | 50 |
| 8. 5. 1. IE0 .....        | 50 |
| 8. 5. 2. IE1 .....        | 51 |
| 8. 5. 3. IP0 .....        | 52 |
| 8. 5. 4. IP1 .....        | 52 |
| 8. 6. 中断优先级及中断嵌套 .....    | 53 |
| 9. I/O 端口 .....           | 54 |
| 9. 1. 结构框图 .....          | 54 |
| 9. 2. 寄存器列表 .....         | 54 |
| 9. 3. 寄存器详细说明 .....       | 56 |
| 9. 3. 1. P0 .....         | 56 |
| 9. 3. 2. P0_PU .....      | 56 |
| 9. 3. 3. P0_PD .....      | 57 |
| 9. 3. 4. P0_MD0 .....     | 58 |
| 9. 3. 5. P0_MD1 .....     | 59 |
| 9. 3. 6. P0_AF0 .....     | 59 |
| 9. 3. 7. P0_AF1 .....     | 60 |
| 9. 3. 8. P0_TRG0 .....    | 61 |
| 9. 3. 9. P0_TRG1 .....    | 62 |
| 9. 3. 10. P0_PND .....    | 63 |
| 9. 3. 11. P0_IMK .....    | 64 |
| 9. 3. 12. P0_AIOEN .....  | 64 |
| 9. 3. 13. P0_DRV .....    | 65 |
| 9. 3. 14. P0_OD .....     | 66 |
| 9. 3. 15. P1 .....        | 67 |



珠海泰芯半导体有限公司  
Zhuhai Taixin Semiconductor Co., Ltd

珠海市高新区港湾一号科创园港 11 栋 3 楼

|      |            |               |      |                     |
|------|------------|---------------|------|---------------------|
| 保密等级 | A          | TX8W7010 用户手册 | 文件编号 | TX-WI-TX8W7010-RD02 |
| 发行日期 | 2022-08-10 |               | 文件版本 | V1.5                |

|                           |    |
|---------------------------|----|
| 9.3.16. P1_PU .....       | 67 |
| 9.3.17. P1_PD .....       | 68 |
| 9.3.18. P1_MD0 .....      | 69 |
| 9.3.19. P1_MD1 .....      | 70 |
| 9.3.20. P1_AF0 .....      | 70 |
| 9.3.21. P1_AF1 .....      | 71 |
| 9.3.22. P1_TRG0 .....     | 71 |
| 9.3.23. P1_TRG1 .....     | 72 |
| 9.3.24. P1_PND .....      | 73 |
| 9.3.25. P1_IMK .....      | 74 |
| 9.3.26. P1_AIOEN .....    | 74 |
| 9.3.27. P1_DRV .....      | 75 |
| 9.3.28. P1_OD .....       | 76 |
| 10. SPI 模块 .....          | 77 |
| 10.1. 功能概述 .....          | 77 |
| 10.2. 模块框图 .....          | 77 |
| 10.3. 寄存器列表 .....         | 78 |
| 10.4. 寄存器详细说明 .....       | 78 |
| 10.4.1. SPI0_CON .....    | 78 |
| 10.4.2. SPI0_BAUD .....   | 79 |
| 10.4.3. SPI0_DATA .....   | 79 |
| 10.4.4. SPI0_STA .....    | 79 |
| 10.5. 使用流程说明 .....        | 80 |
| 11. UART0/1 模块 .....      | 80 |
| 11.1. 功能概述 .....          | 80 |
| 11.2. 模块框图 .....          | 81 |
| 11.3. 寄存器列表 .....         | 81 |
| 11.4. 寄存器详细说明 .....       | 82 |
| 11.4.1. UART0_CON .....   | 82 |
| 11.4.2. UART0_STA .....   | 83 |
| 11.4.3. UART0_BAUD0 ..... | 83 |
| 11.4.4. UART0_BAUD1 ..... | 84 |
| 11.4.5. UART0_DATA .....  | 84 |
| 11.4.6. UART1_CON .....   | 84 |
| 11.4.7. UART1_STA .....   | 85 |
| 11.4.8. UART1_BAUD0 ..... | 86 |
| 11.4.9. UART1_BAUD1 ..... | 86 |



珠海泰芯半导体有限公司  
Zhuhai Taixin Semiconductor Co., Ltd

珠海市高新区港湾一号科创园港 11 栋 3 楼

|      |            |               |      |                     |
|------|------------|---------------|------|---------------------|
| 保密等级 | A          | TX8W7010 用户手册 | 文件编号 | TX-WI-TX8W7010-RD02 |
| 发行日期 | 2022-08-10 |               | 文件版本 | V1.5                |

|                             |     |
|-----------------------------|-----|
| 11. 4. 10. UART1_DATA ..... | 86  |
| 11. 5. 使用流程说明 .....         | 86  |
| 发送数据: .....                 | 86  |
| 接收数据: .....                 | 87  |
| 12. 基本 Timer 0/1 模块 .....   | 87  |
| 12. 1. 功能概述 .....           | 87  |
| 12. 2. 模块框图 .....           | 88  |
| 12. 3. 寄存器列表 .....          | 88  |
| 12. 4. 寄存器详细说明 .....        | 89  |
| 12. 4. 1. TMR0_CONL .....   | 89  |
| 12. 4. 2. TMR0_CONH .....   | 90  |
| 12. 4. 3. TMR0_CNTL .....   | 91  |
| 12. 4. 4. TMR0_PRL .....    | 91  |
| 12. 4. 5. TMR0_PWML .....   | 91  |
| 12. 4. 6. TMR1_CONL .....   | 91  |
| 12. 4. 7. TMR1_CONH .....   | 92  |
| 12. 4. 8. TMR1_CNTL .....   | 93  |
| 12. 4. 9. TMR1_PRL .....    | 93  |
| 12. 4. 10. TMR1_PWML .....  | 93  |
| 12. 5. 使用流程说明 .....         | 94  |
| 12. 5. 1. 计数器/定时器工作模式 ..... | 94  |
| 12. 5. 2. 捕获工作模式 .....      | 94  |
| 12. 5. 3. PWM 工作模式 .....    | 95  |
| 13. 基本 Timer2 模块 .....      | 95  |
| 13. 1. 功能概述 .....           | 95  |
| 13. 2. 模块框图 .....           | 96  |
| 13. 3. 寄存器列表 .....          | 96  |
| 13. 4. 寄存器详细说明 .....        | 97  |
| 13. 4. 1. TMR2_CONL .....   | 97  |
| 13. 4. 2. TMR2_CONH .....   | 98  |
| 13. 4. 3. TMR2_CNTL .....   | 99  |
| 13. 4. 4. TMR2_CNTH .....   | 99  |
| 13. 4. 5. TMR2_PRL .....    | 99  |
| 13. 4. 6. TMR2_PRH .....    | 99  |
| 13. 4. 7. TMR2_PWML .....   | 99  |
| 13. 4. 8. TMR2_PWMH .....   | 100 |



珠海泰芯半导体有限公司  
Zhuhai Taixin Semiconductor Co., Ltd

珠海市高新区港湾一号科创园港 11 栋 3 楼

|      |            |               |      |                     |
|------|------------|---------------|------|---------------------|
| 保密等级 | A          | TX8W7010 用户手册 | 文件编号 | TX-WI-TX8W7010-RD02 |
| 发行日期 | 2022-08-10 |               | 文件版本 | V1.5                |

|                             |     |
|-----------------------------|-----|
| 13.5. 使用流程说明 .....          | 100 |
| 13.5.1. 计数器/定时器工作模式 .....   | 100 |
| 13.5.2. 捕获工作模式 .....        | 101 |
| 13.5.3. PWM 工作模式 .....      | 101 |
| 14. 高级 Timer 1/2 模块 .....   | 102 |
| 14.1. 功能概述 .....            | 102 |
| 14.1.1. 基本动作 .....          | 103 |
| 14.1.2. 时钟源选择 .....         | 105 |
| 14.1.3. 计数方向 .....          | 106 |
| 14.1.4. 数字滤波 .....          | 107 |
| 14.1.5. 软件同步 .....          | 107 |
| 14.1.6. 缓存功能 .....          | 109 |
| 14.1.7. 通用 PWM 输出 .....     | 110 |
| 14.1.8. 周期间隔响应 .....        | 112 |
| 14.1.9. 保护机制 .....          | 113 |
| 14.1.10. 中断说明 .....         | 114 |
| 14.1.11. 刹车保护 .....         | 114 |
| 14.1.12. 内部互连 .....         | 114 |
| 14.1.13. 红外功能 .....         | 114 |
| 14.2. 模块框图 .....            | 115 |
| 14.3. 寄存器列表 .....           | 115 |
| 14.4. 寄存器详细说明 .....         | 117 |
| 14.4.1. STMR1_CR .....      | 117 |
| 14.4.2. STMR1_FCONR .....   | 118 |
| 14.4.3. STMR1_CNTL .....    | 118 |
| 14.4.4. STMR1_CNTH .....    | 119 |
| 14.4.5. STMR1_PRL .....     | 119 |
| 14.4.6. STMR1_PRH .....     | 119 |
| 14.4.7. STMR1_CMPAL .....   | 119 |
| 14.4.8. STMR1_CMPAH .....   | 119 |
| 14.4.9. STMR1_CMPBL .....   | 120 |
| 14.4.10. STMR1_CMBPH .....  | 120 |
| 14.4.11. STMR1_VPERR .....  | 120 |
| 14.4.12. STMR1_DTUA .....   | 121 |
| 14.4.13. STMR1_BRAKE .....  | 121 |
| 14.4.14. STMR1_DTR .....    | 122 |
| 14.4.15. STMR1_PCONRA ..... | 123 |
| 14.4.16. STMR1_PCONRB ..... | 124 |
| 14.4.17. STMR1_IE .....     | 125 |

|      |            |               |      |                     |
|------|------------|---------------|------|---------------------|
| 保密等级 | A          | TX8W7010 用户手册 | 文件编号 | TX-WI-TX8W7010-RD02 |
| 发行日期 | 2022-08-10 |               | 文件版本 | V1.5                |

|                               |            |
|-------------------------------|------------|
| 14. 4. 18. STMR1_SR .....     | 126        |
| 14. 4. 19. STMR2_CR .....     | 127        |
| 14. 4. 20. STMR2_FCONR .....  | 128        |
| 14. 4. 21. STMR2_PRL .....    | 128        |
| 14. 4. 22. STMR2_PRH .....    | 129        |
| 14. 4. 23. STMR2_CMPAL .....  | 129        |
| 14. 4. 24. STMR2_CMPAH .....  | 129        |
| 14. 4. 25. STMR2_CMPBL .....  | 129        |
| 14. 4. 26. STMR2_CMPBH .....  | 130        |
| 14. 4. 27. STMR2_VPERR .....  | 130        |
| 14. 4. 28. STMR2_DTUA .....   | 131        |
| 14. 4. 29. STMR2_BRAKE .....  | 131        |
| 14. 4. 30. STMR2_DTR .....    | 132        |
| 14. 4. 31. STMR2_PCONRA ..... | 133        |
| 14. 4. 32. STMR2_PCONRB ..... | 134        |
| 14. 4. 33. STMR2_IE .....     | 135        |
| 14. 4. 34. STMR2_SR .....     | 136        |
| 14. 4. 35. STMR_ALLCON .....  | 137        |
| 14. 5. 使用流程说明 .....           | 137        |
| <b>15. CRC16 模块 .....</b>     | <b>138</b> |
| 15. 1. 功能概述 .....             | 138        |
| 15. 2. 基本功能 .....             | 138        |
| 15. 3. 模块框图 .....             | 139        |
| 15. 4. 寄存器列表 .....            | 139        |
| 15. 5. 寄存器详细说明 .....          | 139        |
| 15. 5. 1. CRC_REG .....       | 139        |
| 15. 5. 2. CRC_FIFO .....      | 140        |
| 15. 6. 使用流程说明 .....           | 140        |
| <b>16. FLASH 控制器模块 .....</b>  | <b>140</b> |
| 16. 1. 功能概述 .....             | 140        |
| 16. 2. 模块框图 .....             | 141        |
| 16. 3. 寄存器列表 .....            | 141        |
| 16. 4. 寄存器详细说明 .....          | 142        |
| 16. 4. 1. FLASH_CON .....     | 142        |
| 16. 4. 2. FLASH_STA .....     | 142        |
| 16. 4. 3. FLASH_DATA .....    | 143        |



珠海泰芯半导体有限公司  
Zhuhai Taixin Semiconductor Co., Ltd

珠海市高新区港湾一号科创园港 11 栋 3 楼

|      |            |               |      |                     |
|------|------------|---------------|------|---------------------|
| 保密等级 | A          | TX8W7010 用户手册 | 文件编号 | TX-WI-TX8W7010-RD02 |
| 发行日期 | 2022-08-10 |               | 文件版本 | V1.5                |

|                              |     |
|------------------------------|-----|
| 16. 4. 4. FLASH_TIM0 .....   | 143 |
| 16. 4. 5. FLASH_TIM1 .....   | 144 |
| 16. 4. 6. FLASH_CRCLEN ..... | 145 |
| 16. 4. 7. FLASH_PSWD .....   | 145 |
| 16. 4. 8. FLASH_ADDR .....   | 146 |
| 16. 4. 9. FLASH_TRIM .....   | 146 |
| 16. 5. 使用流程说明 .....          | 146 |
| 17. 模数转换器(ADC) .....         | 147 |
| 17. 1. 功能概述 .....            | 147 |
| 17. 2. 基本功能 .....            | 148 |
| 17. 2. 1. 单通道触发模式 .....      | 148 |
| 17. 2. 2. 双通道触发模式 .....      | 148 |
| 17. 2. 3. 单通道触发延迟模式 .....    | 148 |
| 17. 2. 4. 模拟校准/数字校准 .....    | 149 |
| 17. 3. 模块框图 .....            | 150 |
| 17. 4. 寄存器列表 .....           | 150 |
| 17. 5. 寄存器详细说明 .....         | 151 |
| 17. 5. 1. ADC_CFG0 .....     | 151 |
| 17. 5. 2. ADC_CFG1 .....     | 152 |
| 17. 5. 3. ADC_CFG2 .....     | 153 |
| 17. 5. 4. ADC_CFG3 .....     | 153 |
| 17. 5. 5. ADC_STA .....      | 154 |
| 17. 5. 6. ADC_DATAHO .....   | 154 |
| 17. 5. 7. ADC_DATALO .....   | 155 |
| 17. 5. 8. ADC_DATAH1 .....   | 155 |
| 17. 5. 9. ADC_DATAL1 .....   | 155 |
| 17. 5. 10. ADC_CHS0 .....    | 155 |
| 17. 5. 11. ADC_CHS1 .....    | 156 |
| 17. 6. 使用流程说明 .....          | 158 |
| 18. 模拟比较器(CMP0/1) .....      | 158 |
| 18. 1. 功能概述 .....            | 158 |
| 18. 2. 模块框图 .....            | 159 |
| 18. 3. 引脚对应表 .....           | 160 |
| 18. 4. 寄存器列表 .....           | 161 |
| 18. 5. 寄存器详细说明 .....         | 162 |
| 18. 5. 1. CMP0_CON0 .....    | 162 |



珠海泰芯半导体有限公司  
Zhuhai Taixin Semiconductor Co., Ltd

珠海市高新区港湾一号科创园港 11 栋 3 楼

|      |            |               |      |                     |
|------|------------|---------------|------|---------------------|
| 保密等级 | A          | TX8W7010 用户手册 | 文件编号 | TX-WI-TX8W7010-RD02 |
| 发行日期 | 2022-08-10 |               | 文件版本 | V1.5                |

|                               |            |
|-------------------------------|------------|
| 18.5.2. CMP0_CON1 .....       | 162        |
| 18.5.3. CMP0_CON2 .....       | 163        |
| 18.5.4. CMP0_CON3 .....       | 164        |
| 18.5.5. CMP0_CON4 .....       | 165        |
| 18.5.6. CMP0_DAC0 .....       | 165        |
| 18.5.7. CMP0_DAC1 .....       | 166        |
| 18.5.8. CMP1_CON0 .....       | 166        |
| 18.5.9. CMP1_CON1 .....       | 167        |
| 18.5.10. CMP1_CON2 .....      | 167        |
| 18.5.11. CMP1_CON3 .....      | 168        |
| 18.5.12. CMP1_CON4 .....      | 169        |
| 18.5.13. CMP1_DAC0 .....      | 169        |
| 18.5.14. CMP1_DAC1 .....      | 170        |
| 18.5.15. CMP_CON .....        | 170        |
| 18.5.16. CMP_STA .....        | 171        |
| <b>19.2.4G RF 收发器模块 .....</b> | <b>172</b> |
| 19.1. 功能描述 .....              | 172        |
| ● 无线部分特性 .....                | 172        |
| ● 射频综合器 .....                 | 172        |
| ● 发射器 .....                   | 172        |
| ● 接收器 .....                   | 172        |
| 19.2. 模块框图 .....              | 173        |
| 19.3. 寄存器列表 .....             | 173        |
| 19.4. 寄存器详细说明 .....           | 175        |
| 19.4.1. CONFIG .....          | 175        |
| 19.4.2. EN_AA .....           | 176        |
| 19.4.3. EN_RXADDR .....       | 177        |
| 19.4.4. PMU_CTL .....         | 177        |
| 19.4.5. SETUP_RETR .....      | 178        |
| 19.4.6. RF_CH .....           | 179        |
| 19.4.7. RF_SETUP .....        | 179        |
| 19.4.8. STATUS .....          | 180        |
| 19.4.9. RX_ADDR_P0 .....      | 181        |
| 19.4.10. RX_ADDR_P1 .....     | 181        |
| 19.4.11. RX_ADDR_P2 .....     | 181        |
| 19.4.12. TX_ADDR .....        | 181        |
| 19.4.13. RX_PW_P0 .....       | 182        |
| 19.4.14. RX_PW_P1 .....       | 182        |
| 19.4.15. RX_PW_P2 .....       | 183        |
| 19.4.16. FIFO_STATUS .....    | 184        |



珠海泰芯半导体有限公司  
Zhuhai Taixin Semiconductor Co., Ltd

珠海市高新区港湾一号科创园港 11 栋 3 楼

|      |            |               |      |                     |
|------|------------|---------------|------|---------------------|
| 保密等级 | A          | TX8W7010 用户手册 | 文件编号 | TX-WI-TX8W7010-RD02 |
| 发行日期 | 2022-08-10 |               | 文件版本 | V1.5                |

|                              |     |
|------------------------------|-----|
| 19. 4. 17. CONFIG_EXT .....  | 184 |
| 19. 4. 18. DYNPD .....       | 185 |
| 19. 4. 19. FEATURE .....     | 185 |
| 19. 4. 20. SETUP_VALUE ..... | 186 |
| 19. 4. 21. PRE_GURD .....    | 186 |
| 19. 4. 22. LINE .....        | 187 |
| 19. 4. 23. PLL_CTL0 .....    | 187 |
| 19. 4. 24. PLL_CTL1 .....    | 190 |
| 19. 4. 25. CAL_CTL .....     | 191 |
| 19. 4. 26. STATUS .....      | 192 |
| 19. 4. 27. STATE .....       | 193 |
| 19. 4. 28. CHAN .....        | 193 |
| 19. 4. 29. FDEV .....        | 194 |
| 19. 4. 30. DAC_RANGE .....   | 194 |
| 19. 4. 31. CTUNING .....     | 194 |
| 19. 4. 32. FTUNING .....     | 195 |
| 19. 4. 33. RX_CTRL .....     | 195 |
| 19. 4. 34. FAGC_CTRL_1 ..... | 196 |
| 19. 4. 35. DOC_DACI .....    | 196 |
| 19. 4. 36. DOC_DACQ .....    | 197 |
| 19. 4. 37. AGC_CTRL .....    | 197 |
| 19. 4. 38. AGC_GAIN .....    | 198 |
| 19. 4. 39. RF_IVGEN .....    | 198 |
| 19. 4. 40. TEST_PKDET .....  | 200 |
| 19. 5. 应用使用说明 .....          | 200 |
| 19. 5. 1. 普通 2.4G 模式 .....   | 200 |



珠海泰芯半导体有限公司  
Zhuhai Taixin Semiconductor Co., Ltd

珠海市高新区港湾一号科创园港 11 栋 3 楼

# 1. 产品概述

## 1.1. 说明

TX8W7010 是一款支持 2.4G 无线通信功能，高性能低功耗的 8051 内核的无线 MCU，工作主频最高为 32MHz，内置 4K+256 字节闪存存储器（支持类 EEPROM），512 字节 SRAM。

TX8W7010 是一款嵌入基带通信协议的单片 2.4GHz 收发芯片，工作在 2.4GHz~2.483GHz 世界通用的 ISM 频段，适用于超低功耗无线应用领域。该芯片集成了射频收发器、频率合成器、多通信模式控制器、调制器、解调器等功能模块。可以对输出功率、频道选择以及协议的设置等用途进行灵活配置。采用 GFSK, FSK 调制，支持 2Mbps, 1Mbps 的数据速率，最大发射功率可以达到 8dBm，接收灵敏度在 1Mbps 速率下可以达到 -90dBm。

模拟资源： 1 个 12 位 200Ksps 的 ADC、2 个多功能比较器

定时器、PWM 资源（两者是互斥功能，同一个 Timer 不能同时使用）：

- 2 个 16 位高级定时器，能支持 2 对互补输出或 4 个独立 PWM 输出（周期相同，占空比独立配置）
- 1 个 16 位通用定时器（都支持 Capture、Count、PWM 功能）
- 2 个 8 位通用定时器（可合成 1 个 16 位通用定时器，都支持 Capture、Count、PWM 功能）

标准的通信接口：1 个 SPI 接口和 2 个 UART 接口。

支持宽范围电压供电，工作电压为 2.4V ~ 3.6V，工作温度范围 -40°C ~ 85°C。多种省电工作模式保证低功耗应用的要求，最低功耗模式 5uA。

TX8W7010 提供 SOP16 封装形式，应用场合：

- 无线鼠标和键盘
- 玩具和无线音频
- 无线游戏手柄
- 有源无线标签

- 智能家居及安防系统
- 电视和机顶盒遥控
- 无线工控
- 无线航模

## 1.2. 特性

- **内核**
  - 超高速 8051 内核 (1T)
  - 指令全兼容传统 8051
  - 工作最大主频: 32MHz
  - 14 个中断源, 支持硬件两级优先级
  - 支持在线下载
- **工作电压**
  - 2.4V~3.6V 电压范围供电
- **存储器**
  - 4K+256 字节 Flash, 用于存储用户代码, 并且支持类 EEPROM (擦写次数典型值 10 万次)
  - 512 字节 RAM
- **时钟**
  - 内部 1~32MHz 高精度 HIRC, 支持校准 (误差±1%)
  - 内部 64KHz 低速 LIRC, 支持校准 (误差±1%)
  - 外部 32.768 KHz 低速晶振, 需要外部加电容
- **复位**
  - 上电复位
  - 欠压复位
  - 复位脚复位
  - 看门狗溢出复位
- **GPIO**

- 最多可达 9 个 GPIO
  - 所有端口均可输入输出 3.3V 信号
  - 均支持上升沿/下降沿/双边沿中断
  - 均支持唤醒功能
  - 有全驱动和小驱动两个档位。
  - 支持 OD 输出低模式。
  - 支持独立控制的上下拉电阻，阻值 30KΩ
- **LVD 低压检测复位**
  - 提供 4 级低压检测电压 (1.85/2.03V、2.15/2.34V、2.43/2.63V、3.34/3.63V)
- **数字外设**
  - 1 个 SPI 高速串行接口，支持主从模式
  - 2 个 UART 接口，最大支持 4Mbps
- **定时器资源**
  - 2 个 16 位高级定时器，能支持 2 对互补输出或 4 个独立 PWM 输出（周期相同，占空比独立配置），支持死区插入和事件刹车功能，支持单脉冲模式
  - 1 个 16 位通用定时器，都支持 Capture、Count、PWM 功能
  - 2 个 8 位通用定时器（可合成 1 个 16 位通用定时器，都支持 Capture、Count、PWM 功能），可以支持红外发送和接收功能（需要两个 Timer）
  - 1 个看门狗定时器
- **高安全性**
  - 支持 16 bit CRC 效验，保证数据准确性
- **低功耗**
  - 支持 Idle、Stop、Sleep 低功耗模式
  - 静态功耗 5uA @25°C
  - 低功耗唤醒时间小于 100us
- **2 个模拟比较器(ACMP)**
  - 2 个低失调比较器，校正 step 1mV
  - 比较器支持负端输入精准 BG 的 120 个分压档位

- 两个比较器都支持轨到轨输入模式，正负端各支持 2 个 GPIO 可选
- 支持短路保护

- **无线部分特性**

- 通信频段：2.400GHz ~ 2.483GHz
- 支持 BLE 广播包
- 支持长包模式（最大 255Byte）
- 数据速率：2Mbps, 1Mbps
- 调制方式：GFSK, FSK
- 126 个射频信道

- **射频综合器**

- 完全集成频率合成器
- 不需要外部环路滤波器 (LF) 和压控振荡器 (VCO)
- 可接受低成本的晶体：±60ppm 16MHz 晶体

- **发射器**

- 可编程的发射功率：-34 ~ +8 dBm
- 发射功率为 0dBm 时，工作电流为 17mA

- **接收器**

- 快速 AGC 功能
- 集成通道滤波器
- 空口速率为 2Mbps 时，工作电流为 18mA
- 空口速率为 2Mbps 时，接收灵敏度为 -87dBm
- 空口速率为 1Mbps 时，接收灵敏度为 -90dBm

- **高可靠性**

- ESD HBM 6KV
- Latch-up ±200mA @25°C

- **96 位的芯片唯一 ID (UID)**

- **封装**

- SOP16

- **工作温度范围**

➤ -40°C ~ 85°C

### 1.3. 引脚分配



图 1-1 TX8W7010S016 引脚图

### 1.4. 封装信息

TX8W7010 系列的型号如下表格：

| 型号           | 封装    | 包装 |
|--------------|-------|----|
| TX8W7010S016 | SOP16 | 管装 |

### 1.5. 封装尺寸图



图 1-2 SOP16 封装 POD 图

## 1.6. 引脚说明

| 引脚名字  | I/O | 功能描述                                          | 复位状态      | 复用功能                                                                                              |
|-------|-----|-----------------------------------------------|-----------|---------------------------------------------------------------------------------------------------|
| XTALP | A   | 16MHz 晶振输入                                    | —         | 无                                                                                                 |
| XTALN | A   | 16MHz 晶振输出                                    | —         | 无                                                                                                 |
| RFP   | A   | RF 天线                                         | —         | 无                                                                                                 |
| CDVDD | A   | RF VDD 输出, 外接一个退耦电容                           | —         | 无                                                                                                 |
| VCC   | A   | 供电电源 2.4V ~ 3.6V                              | —         | 无                                                                                                 |
| VSS   | A   | 地                                             | —         | 无                                                                                                 |
| VSSRF | A   | RF 地                                          | —         | 无                                                                                                 |
| P01   | I/O | PO 口每个口都可以设置为输入或者输出模式输入模块可以使能内部上拉输出模块可以设置开漏输出 | 引脚默认为高阻输入 | P01<br>PWM2【Timer2 的 PWM 输出】<br>UART1_TX【UART1 TX 发送引脚】<br>HDA【烧写/调试数据引脚】<br>CMP1-【比较器 1 的负端输入引脚】 |

|     |     |                                               |                          |                                                                                                                                                                                           |
|-----|-----|-----------------------------------------------|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P05 |     |                                               |                          | P05<br>STMR2_PWM_A【高级 Timer2 的 CHA PWM 输出】<br>TO【通用 Timer0 的捕获输入引脚】                                                                                                                       |
| P06 |     |                                               |                          | P06<br>STMR1_PWM_B【高级 Timer1 的 CHB PWM 输出】<br>PWMO【Timer0 的 PWM 输出】<br>STMR2_PWM_A【高级 Timer2 的 CHA PWM 输出】                                                                                |
| P07 |     |                                               |                          | P07<br>SDA【IIC 的数据引脚】<br>CMPO_DOUT【比较器0的数字输出引脚】<br>PWM2【Timer2的PWM输出】<br>UARTO_RX【UARTO_RX接收】<br>HDA【烧写/调试数据引脚】                                                                           |
| P10 | I/O | P1 口每个口都可以设置为输入或者输出模式输入模块可以使能内部上拉输出模块可以设置开漏输出 | P10 默认认为上拉打开，其他引脚默认为高阻输入 | P10<br>HCK【烧写/调试时钟引脚】<br>SCL【IIC 的时钟引脚】                                                                                                                                                   |
| P12 |     |                                               |                          | P12<br>STMR2_PWM_B【高级 Timer2 的 CHB PWM 输出】<br>STMR1_PWM_B【高级 Timer1 的 CHB PWM 输出】<br>PWM1【Timer1的PWM输出】<br>UARTO_RX【UARTO_RX接收】<br>CMPO+【比较器0的正端输入引脚】<br>XOSC32_O【外部 32.768KHz 晶振输出引脚】    |
| P13 |     |                                               |                          | P13<br>STMR2_PWM_A【高级 Timer2 的 CHA PWM 输出】<br>STMR1_PWM_A【高级 Timer1 的 CHA PWM 输出】<br>PWM2【Timer2的PWM输出】<br>UARTO_TX【UARTO_TX发送引脚】<br>CMP1+【比较器1的正端输入引脚】<br>XOSC32_IN【外部 32.768KHz 晶振输入引脚】 |
| P14 |     |                                               |                          | P14<br>CMP1_DOUT【比较器1的数字输出引脚】<br>TO【通用 Timer0 的捕获输入引脚】<br>CMPO-【比较器0的负端输入引脚】                                                                                                              |

|     |  |  |  |                                               |
|-----|--|--|--|-----------------------------------------------|
| P15 |  |  |  | P15                                           |
|     |  |  |  | CMPO_DOUT【比较器0的数字输出引脚】<br>T1【通用Timer1的捕获输入引脚】 |

## 2. 中央处理器

TX8W7010 全兼容传统的 8051 微控制器，所有指令的助记符和二进制码都和 8051 兼容。

TX8W7010 的处理器采用了一些体系结构上的优化，扩展了 SP、DPTR 等常用的寄存器，相比传统的 8051 在性能上面有了很大的提升。

TX8W7010 内部的 ALU 配合内部的 ACC (0xE0)、B (0xF0)、PSW (0xD0) 寄存器可以实现各种 8 位运算操作。

ALU 可以进行典型操作如下：

- 基本算术运算：加法、减法、乘法、除法
- 其他算术运算：自加、自减、BCD 调整、比较
- 逻辑运算：与、或、异或、取反、移位
- 布尔比特运算：置位、清零、取反、按位判断跳转、进位操作

### 2.1. 累加器 (ACC)

ALU 是 8Bit 宽的算术逻辑单元，MCU 所有的数学、逻辑运算均通过它来完成。它可以对数据进行加、减、移位及逻辑运算；ALU 也控制状态位（PSW 状态寄存器中），用来表示运算结果的状态。

ACC 寄存器是一个 8Bit 的寄存器，ALU 的运算结果可以存放在此。

Addr = 0xE0 (SFR)

| Bit(s) | Name | Description | R/W | Reset |
|--------|------|-------------|-----|-------|
| 7:0    | ACC  | 累加器寄存器      | RW  | 0x0   |

## 2.2. 寄存器 (B)

B 寄存器在使用乘法和除法指令时使用, 乘法结果高 8bit, 除法结果低 8bit。如不使用乘除法指令, 也可作为通用寄存器使用。

Addr = 0xF0 (SFR)

| Bit(s) | Name | Description | R/W | Reset |
|--------|------|-------------|-----|-------|
| 7:0    | B    | B 寄存器       | RW  | 0x0   |

## 2.3. 堆栈指针寄存器 (SP)

SP 寄存器指向堆栈的低 8bit 地址, 复位后默认值为 0x07, 该 SP 的值可以修改。影响 SP 的操作有: 指令 PUSH、LCALL、ACALL、POP、RET、RETI 以及进入中断。

Addr = 0x81 (SFR)

| Bit(s) | Name | Description | R/W | Reset |
|--------|------|-------------|-----|-------|
| 7:0    | SP   | 堆栈指针寄存器     | RW  | 0x7   |

## 2.4. 堆栈指针寄存器 (SPH)

SPH 寄存器指向堆栈高 8bit 地址, 有效位 1bit, 复位后默认值位 0x0, 与 SP 组合使用, 意味着堆栈的区域从 RAM 地址的 0x07 开始。该值可以修改, 如果将堆栈区域设置为 0x0B 开始, 则在复位后将 SPH 和 SP 的值分别设置为 0x0 和 0xA。

影响 SPH 的操作有: 指令 PUSH、LCALL、ACALL、POP、RET、RETI 以及进入中断。

Addr = 0x9B (SFR)

| Bit(s) | Name | Description | R/W | Reset |
|--------|------|-------------|-----|-------|
| 7:1    | -    | -           | -   | -     |
| 0      | SPH  | 堆栈指针寄存器高位   | RW  | 0x0   |

## 2.5. 数据指针寄存器 (DPTR0/DPTR1)

数据指针主要用在 MOVX, MOVC 指令中，其作用是定位 RAM 与 ROM 的地址。芯片内部有两个数据指针寄存器 DPTR0 与 DPTR1，通过 DPSEL 寄存器选择。

每组指针包括两个 8 位寄存器：DPTR0={DPH0, DPL0}、DPTR1={DPH1, DPL1}。

Addr = 0x82 (SFR)

| Bit(s) | Name | Description      | R/W | Reset |
|--------|------|------------------|-----|-------|
| 7:0    | DPL0 | DPTR0 数据指针寄存器低八位 | RW  | 0x0   |

Addr = 0x83 (SFR)

| Bit(s) | Name | Description      | R/W | Reset |
|--------|------|------------------|-----|-------|
| 7:0    | DPH0 | DPTR0 数据指针寄存器高八位 | RW  | 0x0   |

Addr = 0x84 (SFR)

| Bit(s) | Name | Description      | R/W | Reset |
|--------|------|------------------|-----|-------|
| 7:0    | DPL1 | DPTR1 数据指针寄存器低八位 | RW  | 0x0   |

Addr = 0x85 (SFR)

| Bit(s) | Name | Description      | R/W | Reset |
|--------|------|------------------|-----|-------|
| 7:0    | DPL1 | DPTR1 数据指针寄存器高八位 | RW  | 0x0   |

## 2.6. 数据指针控制寄存器 (DPCFG)

Addr = 0x86 (SFR)

| Bit(s) | Name | Description | R/W | Reset |
|--------|------|-------------|-----|-------|
|        |      |             |     |       |

|     |       |                                                                                                                                                                   |    |     |
|-----|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|
| 7:6 | IA    | <p><b>中断起始地址和增加方式选择位</b></p> <p>IA[0]</p> <p>0x0: 中断地址= (中断向量*8) +3<br/>0x1: 中断地址= (中断向量+1) *3</p> <p>IA[1]</p> <p>0x0: 中断起始地址为 0x300<br/>0x1: 中断起始地址为 0x8000</p> | RW | 0x2 |
| 5   | DPID0 | <p><b>DPTR0 加 1/减 1</b></p> <p>0x0: DPTR0 加 1<br/>0x1: DPTR0 减 1</p>                                                                                              | RW | 0x0 |
| 4   | DPID1 | <p><b>DPTR1 加 1/减 1</b></p> <p>0x0: DPTR1 加 1<br/>0x1: DPTR1 减 1</p>                                                                                              | RW | 0x0 |
| 3   | DPAID | <p><b>DPTR0/DPTR1 自加自减使能位</b></p> <p>0x0: 关闭<br/>0x1: 打开</p>                                                                                                      | RW | 0x0 |
| 2   | DPTSL | <p><b>DPSEL 自动翻转使能位</b></p> <p>0x0: 关闭<br/>0x1: 打开</p>                                                                                                            | RW | 0x0 |
| 1   | -     | -                                                                                                                                                                 | -  | -   |
| 0   | DPSEL | <p><b>选择 DPTR0 /DPTR1 位</b></p> <p>0x0: DPTR0 有效<br/>0x1: DPTR1 有效</p>                                                                                            | RW | 0x0 |

## 2.7. 程序状态寄存器 (PSW)

Addr = 0xD0 (SFR)

| Bit(s) | Name     | Description                                                         | R/W | Reset |
|--------|----------|---------------------------------------------------------------------|-----|-------|
| 7      | CY       | 进位标志位<br>0x0: 无进位<br>0x1: 有进位                                       | RW  | 0x0   |
| 6      | AC       | 辅助进位标志位<br>0x0: 无进位<br>0x1: 有进位                                     | RW  | 0x0   |
| 5      | F0       | 通用标志位 0                                                             | RW  | 0x0   |
| 4:3    | RS1, RS0 | 寄存器组选择位<br>0x0: 寄存器组 0<br>0x1: 寄存器组 1<br>0x2: 寄存器组 2<br>0x3: 寄存器组 3 | RW  | 0x0   |
| 2      | OV       | 溢出标志位<br>0x0: 算术或逻辑运算无溢出<br>0x1: 算术或逻辑运算有溢出                         | RW  | 0x0   |
| 1      | F1       | 通用标志位 1                                                             | RW  | 0x0   |
| 0      | P        | 奇偶校验标志位<br>0x0: ACC 中 1 为偶数<br>0x1: ACC 中 1 为奇数                     | RW  | 0x0   |

## 2.8. 程序计数器 (PC)

程序计数器 (PC) 控制程序内存 FLASH 中的指令执行顺序，它可以寻址整个 FLASH 的范围，取得指令码后，程序计数器 (PC) 会自动加一，指向下一个指令码的地址。但如果执行跳转、条件跳转、向 PCL 赋值、子程序调用、初始化复位、中断、中断返回、子程序返

回等操作时，PC 会加载与指令相关的地址而不是下一条指令的地址。

当遇到条件跳转指令且符合跳转条件时，当前指令执行过程中读取的下一条指令将会被丢弃，且会插入一个空指令操作周期，随后才能取得正确的指令。反之，就会顺序执行下一条指令。

### 3. 存储器

TX8W7010 有内部有 3 种存储器：IDATA、XDATA、程序存储器。

程序存储只能读不能写，程序存储器大小为 4K 字节。XDATA 大小为 1K 字节（其中 XSFR 为 512 字节），IDATA 大小为 256 字节。

#### 3.1. 程序存储器

TX8W7010 的程序指针为 16 位，最大寻址空间可达 64K 字节，实际只实现了 4K 字节的程序存储空间。



图 3-1 程序存储空间

复位后，MCU 从 0x8000 开始执行。从 0x8003 开始是中断向量表，当发生中断且中断使能后，PC 会跳转到对应的中断向量位置去执行。

### 3.2. XDATA

XDATA 共有 256 字节，地址为 0x300~0x3FF，可用于数据存储。

### 3.3. IDATA

内部数据存储器空间大小为 256 字节。

内部数据存储器的地址空间的低 128 字节可以字节访问，高 128 字节和 SFR 共用一个地址空间，直接访问高 128 字节会访问到 SFR 空间，高 128 字节数据存储器只能通过间接寻址方式访问。



图 3-2 数据存储器



图 3-3 内部低 128 字节数据空间分配

### 3. 4. SFR 空间

|            | 0H/8H        | 1H/9H       | 2H/AH        | 3H/BH        | 4H/CH       | 5H/DH        | 6H/EH          | 7H/FH        |
|------------|--------------|-------------|--------------|--------------|-------------|--------------|----------------|--------------|
| <b>F8H</b> | UART0_BAUD0  | UART0_BAUD1 | UART0_DATA   | UART1_CON    | UART1_STA   | UART1_BAUD0  | UART1_BAUD1    | UART1_DATA   |
| <b>F0H</b> | B            | -           | -            | -            | -           | STMR_ALLCON  | UART0_CON      | UART0_STA    |
| <b>E8H</b> | STMR2_BRAKE  | STMR2_DTR   | STMR2_PCONRA | STMR2_PCONRB | STMR2_IE    | STMR2_SR     | ADK_CFG3       | -            |
| <b>E0H</b> | ACC          | STMR2_CMPAH | STMR2_CMBPL  | STMR2_CMPBH  | STMR2_CR    | STMR2_FCONR  | STMR2_VPERR    | STMR2_DTUA   |
| <b>D8H</b> | STMR1_PCONRB | STMR1_IE    | STMR1_SR     | STMR2_CNTL   | STMR2_CNTH  | STMR2_PRL    | STMR2_PRH      | STMR2_CMPAL  |
| <b>D0H</b> | PSW          | STMR1_CR    | STMR1_FCONR  | STMR1_VPERR  | STMR1_DTUA  | STMR1_BRAKE  | STMR1_DTR      | STMR1_PCONRA |
| <b>C8H</b> | STMR1_CNTL   | STMR1_CNTH  | STMR1_PRL    | STMR1_PRH    | STMR1_CMPAL | STMR1_CMPAH  | STMR1_CMBPL    | STMR1_CMPBH  |
| <b>C0H</b> | TMR2_CONL    | TMR2_CONH   | TMR2_CNTL    | TMR2_CNTH    | TMR2_PRL    | TMR2_PRH     | TMR2_PWML      | TMR2_PWMH    |
| <b>B8H</b> | IPO          | IP1         | LVD_CON0     | LVD_CON1     | LVD_CON2    | LVD_CON3     | LP_CON         | SYS_PND      |
| <b>B0H</b> | TMR1_CONL    | TMR1_CONH   | TMR1_CNTL    | TMR1_CNTH    | TMR1_PRL    | TMR1_PRH     | TMR1_PWML      | TMR1_PWMH    |
| <b>A8H</b> | IE0          | IE1         | FLASH_TRIM   | WKUP_CON0    | WKUP_PND    | WDT_CON      | WDT_KEY        | -            |
| <b>A0H</b> | FLASH_CON    | FLASH_STA   | FLASH_DATA   | FLASH_TIM0   | FLASH_TIM1  | FLASH_CRCLEN | FLASH_PASSWORD | FLASH_ADDR   |
| <b>98H</b> | -            | -           | -            | SPH          | PCON1       | -            | CRC_REG        | CRC_FIFO     |
| <b>90H</b> | P1           | -           | -            | -            | -           | -            | -              | -            |
| <b>88H</b> | TMRO_CONL    | TMRO_CONH   | TMRO_CNTL    | TMRO_CNTH    | TMRO_PRL    | TMRO_PRH     | TMRO_PWML      | TMRO_PWMH    |
| <b>80H</b> | P0           | SP          | DPL0         | DPH0         | DPL1        | DPH1         | DPS            | PCONO        |

## 4. 系统时钟

### 4.1. 时钟系统概述

系统片上有一个 32MHz 的高速高精度 RC 振荡器，和一个外接的 32.768KHz 的低速晶体振荡器，以及内部 PMU 里面集成了一个 64KHz 的低速 RC 振荡器。

### 4.2. 时钟系统主要功能

TX8W7010 芯片的时钟源来自于 3 个不同的时钟，分别是片外 32.768KHz 的低速晶振，片内 64K 低速 RC 和片内 32M 高速 RC。如图 4-1 所示，系统时钟可以通过 CLK\_CON0[1:0]对上述三个时钟源进行选择，选择后的时钟为芯片工作最快时钟（下文称为 sys\_clk\_pre）。如图 4-2 所示，sys\_clk\_pre 再经过 CLK\_CON2[3:0]进行分频，分频后时钟为系统时钟（下文称为 sys\_clk），系统中大部分外设与模数混合模块都将使用 sys\_clk，例如 UART、CRC16 等外设都使用 sys\_clk。如图 4-2 所示，GPIO 口的滤波时钟，Timer2 模块时钟和低电检测这几个特殊的模块会使用 sys\_clk，片外 32.768KHz 的低速晶振，片内 64K 低速 RC，片内 32M 高速 RC 分频后时钟进行选择。

### 4.3. 时钟系统框图



图 4-1 系统时钟框图



图 4-2 模块时钟框图

## 4.4. 系统振荡器

### 4.4.1. 内部低速 RC 振荡器

PMU 内部集成了一个 64KHz 的常开低速 RC 振荡器，当芯片上电时，系统工作在该 64KHz 的时钟，完成上电复位过程，等到系统复位释放以后才开始跑程序。

### 4.4.2. 内部高速 RC 振荡器

芯片内部集成了一个片上高速 RC 振荡器，支持最大 32MHz 的输出时钟给系统用，默认时关闭的，需要用户在程序中通过配置系统寄存器 AIP\_CON0[7]=1，打开高速 RC 振荡器，也可以通过配置 AIP\_CON0[7]=0，关闭该时钟源。注意在关闭该时钟前，系统需要先切换到低速 RC 振荡器。该高速 RC 振荡器可以通过量产过程中的校准程序校准，保证其精度满足应用方案需求。

### 4.4.3. 外部低速晶体振荡器

芯片内部集成了一个晶体振荡器启振电路，可以外部接一个低速 32.768KHz 的无源晶体振荡器，作为系统的工作时钟源。默认时关闭的，可以通过配置系统寄存器 AIP\_CON1[3]=1，打开该时钟源；也可以配置 AIP\_CON1[3]=0，关闭。

## 5. 复位系统

### 5.1. 上电复位

芯片上电的 POR 复位。

### 5.2. 掉电复位掉

芯片掉电的 BOR 复位。

### 5.3. 看门狗复位

芯片有一个独立于系统运行的看门狗模块，用于保护系统异常发生之后的复位重启系统。看门狗模块工作时钟是常开的 64KHz 的低速 RC 的 2 分频时钟，即工作在 32KHz 的独立于系统时钟的时钟。默认配置是 2 秒钟复位一次系统。所以在用户程序中需要在看门狗复位之前要喂狗，使其重新计时。用户可以配置看门狗复位时间间隔范围从 8ms ~ 262s，可以选择看门狗产生中断，不复位。中断和复位只能二选一。

#### 5.3.1. 控制寄存器列表

表 5-1 WDT 寄存器列表

| Address    | Register Name | Description      |
|------------|---------------|------------------|
| 0xAD (SFR) | WDT_CON       | WDT_CON register |
| 0xAE (SFR) | WDT_KEY       | WDT_KEY register |

### 5.3.2. 寄存器详细说明

#### 5.3.2.1. WDT\_CON

Addr = 0xAD (SFR)

| Bit(s) | Name   | Description                                                                                          | R/W | Reset |
|--------|--------|------------------------------------------------------------------------------------------------------|-----|-------|
| 7      | WAKEEN | WDT 唤醒功能使能位<br>写 WDT_KEY=0xEE, 置位<br>写 WDT_KEY=0x22, 复位<br>0x0: 关闭<br>0x1: 打开                        | RO  | 0x0   |
| 6      | WDTPND | WDT 计数器计满标记位<br>写 WDT_KEY=0xAA, 清掉该标记位<br>0x0: 计数器未计满<br>0x1: 计数器计满                                  | RO  | 0x0   |
| 5      | INTEN  | WDT 中断功能使能位<br>写 WDT_KEY=0x5A, 置位<br>写 WDT_KEY=0xA5, 复位<br>0x1: 打开中断功能<br>0x0: 打开复位功能                | RO  | 0x0   |
| 4      | WDTE   | WDT 使能位<br>写 WDT_KEY=0xCC, 置位<br>写 WDT_KEY=0xDD, 复位<br>0x0: 关闭 watchdog 功能<br>0x1: 打开 watchdog 功能    | RW  | 0x1   |
| 3:0    | PSR    | 预分频系数<br>每次配置该位域之前必须先写 WDT_KEY=0x55<br>0x0: 不分频<br>0x1: 2 分频<br>0x2: 4 分频<br>0x3: 8 分频<br>0x4: 16 分频 | RW  | 0x8   |

|  |  |                                                                                                                                                                                                   |  |
|--|--|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|  |  | 0x5: 32 分频<br>0x6: 64 分频<br>0x7: 128 分频<br>0x8: 256 分频<br>0x9: 512 分频<br>0xA: 1024 分频<br>0xB: 2048 分频<br>0xC: 4096 分频<br>0xD: 8192 分频<br>0xE: 16384 分频<br>0xF: 32768 分频<br>看门狗复位时间=1/32K*256*分频系数 |  |
|--|--|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|

### 5.3.2.2 WDT\_KEY

Addr = 0xAE (SFR)

| Bit(s) | Name    | Description                                                                                                                                                                                                                                                        | R/W | Reset |
|--------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7:0    | WDT_KEY | <b>喂狗数据寄存器</b><br>软件必须以一定的间隔写入 0xAA 完成喂狗操作，否则，当计数器为 0 时，看门狗会产生复位<br>当 pending 为 1 的时候，写入 0xAA 清除 pending<br>0x55: 表示允许访问和设置 wdt_psr<br>0xDD: 关闭看门狗<br>0xCC: 启动看门狗工作<br>0xAA: 喂狗并清除 wdt_pending<br>0xA5: 关闭中断<br>0x5A: 开启中断<br>0x22: 关闭 wake up<br>0xEE: 开启 wake up | W0  | 0x0   |

## 5.4. 低电检测复位

PMU 内部集成了低电压检测和过流检测功能电路，用于检测 PMU 供电部分异常情况，并可以把检测到低电压和过流等异常情况通过中断方式上报给 CPU 进行系统异常处理程序。另外低电压异常信号可以产生复位信号去复位系统，以免在低电压的情况下电路工作不正常而导致用户程序跑飞。低电压检测的阈值可以通过 LVD 控制寄存器设置。可以通过设置 LVD 控制寄存器对异常信号进行滤波去抖动，避免系统瞬态变化导致的正常电源压降而误发生意外低电复位系统的情况发生。

### 5.4.1. 控制寄存器列表

表 5-2 LVD 寄存器列表

| Address    | Register Name | Description       |
|------------|---------------|-------------------|
| 0xBA (SFR) | LVD_CON0      | LVD_CON0 register |
| 0xBB (SFR) | LVD_CON1      | LVD_CON1 register |
| 0xBC (SFR) | LVD_CON2      | LVD_CON2 register |
| 0xBD (SFR) | LVD_CON3      | LVD_CON3 register |

### 5.4.2. 寄存器详细说明

#### 5.4.2.1. LVD\_CON0

Addr = 0xBA (SFR)

| Bit(s) | Name  | Description         | R/W | Reset |
|--------|-------|---------------------|-----|-------|
| 7      | -     | -                   | -   | -     |
| 6      | LVDOE | LVD 中断和复位功能输出到系统使能位 | RW  | 0x1   |

|     |             |                                                                                                                                                              |    |     |
|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|
|     |             | 0x0: 关闭<br>0x1: 打开<br><b>Note:</b> 使用 LVD 所有相关功能, 必须把 LVDOE 设置位 1.                                                                                           |    |     |
| 5   | LVDVDDRSTEN | LVD VDD 低电压复位功能使能位<br>0x0: 关闭<br>0x1: 打开                                                                                                                     | RW | 0x1 |
| 4   | LVDVCCRSTEN | LVD VCC 低电压复位功能使能位<br>0x0: 关闭<br>0x1: 打开                                                                                                                     | RW | 0x1 |
| 3:2 | PMULVD5SET  | VCC 电源电压低电检测阈值设置<br>0x0: 1.85/2.03V (掉电检测阈值/上电检测阈值)<br>0x1: 2.15/2.34V (掉电检测阈值/上电检测阈值)<br>0x2: 2.43/2.63V (掉电检测阈值/上电检测阈值)<br>0x3: 3.34/3.63V (掉电检测阈值/上电检测阈值) | RW | 0x0 |
| 1   | PMULVD15EN  | 1.5V 数字逻辑系统工作电压 VDD 低电检测功能使能位<br>0x0: 关闭<br>0x1: 打开                                                                                                          | RW | 0x1 |
| 0   | PMULVD5EN   | VCC 电源 VCC 电压低电检测功能使能位<br>0x0: 关闭<br>0x1: 打开                                                                                                                 | RW | 0x1 |

#### 5.4.2.2. LVD\_CON1

Addr = 0xBB (SFR)

| Bit(s) | Name     | Description                                              | R/W | Reset |
|--------|----------|----------------------------------------------------------|-----|-------|
| 7      | -        | -                                                        | -   | -     |
| 6      | VDDOCPND | VDD 过流检测标记位<br>写 1 清除标记位<br>0x0: VDD 没有过流<br>0x1: VDD 过流 | RW  | 0x0   |

|   |              |                                                          |    |     |
|---|--------------|----------------------------------------------------------|----|-----|
| 5 | LVDVDDPND    | VDD 低电检测标记位<br>写 1 清除标记位<br>0x0: VDD 没有低电<br>0x1: VDD 低电 | RW | 0x0 |
| 4 | LVDVCCPND    | VCC 低电检测标记位<br>写 1 清除标记位<br>0x0: VCC 没有低电<br>0x1: VCC 低电 | RW | 0x0 |
| 3 | LVDVCCSYNDIS | LVD VCC 低电检测同步器关闭位<br>0x0: 打开同步器<br>0x1: 关闭同步器           | RW | 0x1 |
| 2 | VDDOCBPSEN   | VDD 过流滤波去抖功能关闭位<br>0x0: 打开滤波器<br>0x1: 关闭滤波器              | RW | 0x1 |
| 1 | LVDVDDBPSEN  | VDD 低电滤波去抖功能关闭位<br>0x0: 打开滤波器<br>0x1: 关闭滤波器              | RW | 0x1 |
| 0 | LVDVCCBPSEN  | VCC 低电滤波去抖功能关闭位<br>0x0: 打开滤波器<br>0x1: 关闭滤波器              | RW | 0x1 |

#### 5.4.2.3. LVD\_CON2

Addr = 0xBC (SFR)

| Bit(s) | Name     | Description                                                                                                                                 | R/W | Reset |
|--------|----------|---------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7      | -        | -                                                                                                                                           | -   | -     |
| 6:0    | DBSHLMNT | LVD 低电和过流异常检测滤波器高电平滤波时钟周期设置数目<br><br><b>Note:</b> LVD 滤波时钟可以通过系统配置寄存器 CLKCON5[3:2]来选择。用户可以根据使用场景来选择滤波功能。滤波会导致异常发生到系统收到异常会有延迟时间，延迟时间会由设置的滤波的 | RW  | 0x2   |

|  |  |                                                                                                           |  |  |
|--|--|-----------------------------------------------------------------------------------------------------------|--|--|
|  |  | 时钟周期和配置滤波高电平和低电平滤波周期数目共同决定，设置的滤波时钟周期越长，滤波周期数目越多会导致该延迟越长。用户在使用时可以通过对该延迟的容忍度来合理配置。在有些对延迟比较敏感的应用场景可以关闭该滤波功能。 |  |  |
|--|--|-----------------------------------------------------------------------------------------------------------|--|--|

#### 5.4.2.4. LVD\_CON3

Addr = 0xBD (SFR)

| Bit(s) | Name    | Description                                                                                                                                                                                                                                   | R/W | Reset |
|--------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7      | -       | -                                                                                                                                                                                                                                             | -   | -     |
| 6:0    | DBSLLMT | LVD 低电和过流异常检测滤波器低电平滤波时钟周期设置数目<br><br>Note: LVD 滤波时钟可以通过系统配置寄存器 CLKCON5[3:2]来选择。用户可以根据使用场景来选择滤波功能。滤波会导致异常发生到系统收到异常会有延迟时间，延迟时间会由设置的滤波的时钟周期和配置滤波高电平和低电平滤波周期数目共同决定，设置的滤波时钟周期越长，滤波周期数目越多会导致该延迟越长。用户在使用时可以通过对该延迟的容忍度来合理配置。在有些对延迟比较敏感的应用场景可以关闭该滤波功能。 | RW  | 0x2   |

## 6. 低功耗管理

TX8W7010 芯片系统支持 3 个不同功耗等级的低功耗模式，从高到低依次是：Idle Mode、Stop Mode 和 Sleep Mode。其中功耗最低的是 Sleep 低功耗工作模式，该模式下常温整个芯片漏电可以低至 3uA。

## 6. 1. Idle Mode 及唤醒

通过配置系统寄存器 LP\_CON[7]=0，进入 Idle Mode。在 Idle 模式下只有 CPU 工作时钟被关闭，CPU 停止工作。通过中断方式唤醒 Idle Mode，唤醒之后会进入当前唤醒 Idle Mode 的中断服务子程序并执行。

## 6. 2. Stop Mode 及唤醒

通过配置系统寄存器 LP\_CON[1]=1，进入 Stop Mode。在 Stop 模式下系统时钟被关闭，CPU 及大部分系统时钟域的外设停止工作。通过选择多种唤醒源来唤醒 Stop Mode，唤醒源包括：所有 GPIO、比较器、基本 Timer2、看门狗、LVDVCC(电源的低电压检测信号)。Stop Mode 唤醒之后会继续跑后面的用户程序。

## 6. 3. Sleep Mode 及唤醒

通过配置系统寄存器 LP\_CON[0]=1，进入最低功耗的 Sleep Mode。在 Sleep 模式下系统时钟被关闭，CPU 及大部分系统时钟域的外设停止工作，除了 PMU 以外的模拟模块都要关闭，但是 XOSC 可选择开/关。通过选择多种唤醒源来唤醒 Sleep Mode，唤醒源包括：所有 GPIO 电平变换唤醒、基本 Timer2 定时中断唤醒、看门狗复位唤醒。Sleep Mode 唤醒之后可以通过进入 Sleep 模式之前配置的 LP\_CON[6]=1，会继续跑后面的用户程序，如果 LP\_CON[6]=0，则会复位系统重新跑用户程序。

## 6. 4. 低功耗唤醒单元结构图



图 6-1 低功耗唤醒结构图

## 7. 系统控制模块

### 7.1. 功能概述

系统控制模块主要是用来管理和配置系统功能的，包括系统中模拟模块，时钟源，供电系统，时钟管理系统，低功耗及唤醒系统等系统功能配置。

### 7.2. 寄存器列表

表 7-1 系统寄存器列表

| Address     | Register Name | Description       |
|-------------|---------------|-------------------|
| 0x08 (XSFR) | SYS_CON0      | SYS_CON0 register |

|             |           |                    |
|-------------|-----------|--------------------|
| 0x09 (XSFR) | SYS_CON1  | SYS_CON1 register  |
| 0x0A (XSFR) | SYS_CON2  | SYS_CON2 register  |
| 0x0B (XSFR) | SYS_CON3  | SYS_CON3 register  |
| 0x0C (XSFR) | SYS_CON4  | SYS_CON4 register  |
| 0x0D (XSFR) | SYS_CON5  | SYS_CON5 register  |
| 0x10 (XSFR) | CLK_CON0  | CLK_CON0 register  |
| 0x11 (XSFR) | CLK_CON1  | CLK_CON1 register  |
| 0x12 (XSFR) | CLK_CON2  | CLK_CON2 register  |
| 0x13 (XSFR) | CLK_CON3  | CLK_CON3 register  |
| 0x14 (XSFR) | CLK_CON4  | CLK_CON4 register  |
| 0x15 (XSFR) | CLK_CON5  | CLK_CON5 register  |
| 0x16 (XSFR) | CLK_CON6  | CLK_CON6 register  |
| 0x28 (XSFR) | IO_MAP    | IO_MAP register    |
| 0x2A (XSFR) | IO_MAP1   | IO_MAP1 register   |
| 0x30 (XSFR) | AIP_CON0  | AIP_CON0 register  |
| 0x31 (XSFR) | AIP_CON1  | AIP_CON1 register  |
| 0x32 (XSFR) | AIP_CON2  | AIP_CON2 register  |
| 0x33 (XSFR) | AIP_CON3  | AIP_CON3 register  |
| 0x34 (XSFR) | AIP_CON4  | AIP_CON4 register  |
| 0xAB (SFR)  | WKUP_CON0 | WKUP_CON0 register |
| 0xAC (SFR)  | WKUP_PND  | WKUP_PND register  |
| 0xBE (SFR)  | LP_CON    | LP_CON register    |
| 0xBF (SFR)  | SYS_PND   | SYS_PND register   |

## 7.3. 寄存器详细说明

### 7.3.1. SYS\_CON0

Addr = 0x08 (XSFR)

| Bit(s) | Name         | Description                             | R/W | Reset |
|--------|--------------|-----------------------------------------|-----|-------|
| 7      | STMR1SOFTRST | 高级 Timer1 软复位<br>0x0: 软复位<br>0x1: 软复位释放 | RW  | 0x1   |
| 6      | TMR2SOFTRST  | 基本 Timer2 软复位<br>0x0: 软复位<br>0x1: 软复位释放 | RW  | 0x1   |
| 5      | TMR1SOFTRST  | 基本 Timer1 软复位<br>0x0: 软复位<br>0x1: 软复位释放 | RW  | 0x1   |
| 4      | TMROSOFTRST  | 基本 Timer0 软复位<br>0x0: 软复位<br>0x1: 软复位释放 | RW  | 0x1   |
| 3      | I2CSOFTRST   | I2C 软复位<br>0x0: 软复位<br>0x1: 软复位释放       | RW  | 0x1   |
| 2      | -            | -                                       | RW  | 0x1   |
| 1      | UART1SOFTRST | UART1 软复位<br>0x0: 软复位<br>0x1: 软复位释放     | RW  | 0x1   |
| 0      | UARTOSOFTRST | UART0 软复位<br>0x0: 软复位<br>0x1: 软复位释放     | RW  | 0x1   |

### 7.3.2. SYS\_CON1

Addr = 0x09 (XSFR)

| Bit(s) | Name        | Description                                                                                               | R/W | Reset |
|--------|-------------|-----------------------------------------------------------------------------------------------------------|-----|-------|
| 7:6    | MEMDVS[1:0] | 片上 SRAM 动态电压调整值<br><br>Note: 用户千万不要配置该寄存器，否则会导致芯片不确定行为！！！                                                 | RW  | 0x0   |
| 5      | FASTRSTEN   | 快速复位唤醒 Sleep Mode 使能<br><br>配置此功能主要是为了能在 sleep 低功耗模式下，设置通过复位唤醒 sleep 时，可以节省复位时间<br><br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 4      | GPIOSOFRST  | GPIO 模块软复位<br><br>0x0: 软复位<br>0x1: 软复位释放                                                                  | RW  | 0x1   |
| 3      | -           | -                                                                                                         | RW  | 0x1   |
| 2      | WDTSOFRST   | Watchdog 软复位<br><br>0x0: 软复位<br>0x1: 软复位释放                                                                | RW  | 0x1   |
| 1      | CRCSOFRST   | CRC 软复位<br><br>0x0: 软复位<br>0x1: 软复位释放                                                                     | RW  | 0x1   |
| 0      | STMR2SOFRST | 高级 Timer2 软复位<br><br>0x0: 软复位<br>0x1: 软复位释放                                                               | RW  | 0x1   |

### 7.3.3. SYS\_CON2

Addr = 0x0A (XSFR)

| Bit(s) | Name          | Description                                         | R/W | Reset |
|--------|---------------|-----------------------------------------------------|-----|-------|
| 7      | -             | -                                                   | RW  | 0x0   |
| 6      | TMR2SWSYNCBPS | 基础 Timer2 软件同步 bypass 使能位<br><br>0x0: 关闭<br>0x1: 打开 | RW  | 0x1   |

|   |             |                                                                                                          |    |     |
|---|-------------|----------------------------------------------------------------------------------------------------------|----|-----|
| 5 | IODBSSOFRST | I0 debouce 模块软复位<br>0x0: 软复位<br>0x1: 软复位释放                                                               | RW | 0x1 |
| 4 | -           | -                                                                                                        | -  | -   |
| 3 | TMR22IREN   | 基本 Timer2 与高级 Timer2 联合完成红外发送功能使能位<br>基本 Timer2 作为载波 PWM, 高级 Timer2 通道 A 作为调制波 PWM<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 2 | ISDWDTRSTEN | ISD 调试模式下 WDT 复位功能使能位<br>0x0: 关闭<br>0x1: 打开                                                              | RW | 0x0 |
| 1 | -           | -                                                                                                        | -  | -   |
| 0 | LVDVCCWKEN  | LVDVCC 唤醒使能位<br>0x0: 关闭<br>0x1: 打开                                                                       | RW | 0x0 |

**Note:** SYS\_CON2 寄存器中保留位用于特殊测试功能, 用户程序不能随意写操作, 可能会带来系统风险!

#### 7.3.4. SYS\_CON3

Addr = 0x0B (XSFR)

| Bit(s) | Name      | Description                                                                                                                            | R/W | Reset |
|--------|-----------|----------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7:6    | EXTSLPCNT | 低功耗 Sleep Mode 流程退出低功耗 LDO 延迟的时间配置<br>低功耗模式进入之前必须将系统时钟切换成低速的 64KHz 的 RC, 所以延迟时间=n*T64k<br>0x0: 1 个系统周期<br>0x1: 2 个系统周期<br>0x2: 3 个系统周期 | RW  | 0x0   |

|     |             |                                                                                                                                                                                       |    |     |
|-----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|
|     |             | 0x3: 4 个系统周期 (推荐配置)                                                                                                                                                                   |    |     |
| 5:4 | CMPUPCNT    | <p>低功耗 Sleep Mode 流程退出低功耗流程中打开程序存储器供电的延迟时间配置</p> <p>低功耗模式进入之前必须将系统时钟切换成低速的 64KHz 的 RC，所以延迟时间=n*T64k</p> <p>0x0: 1 个系统周期<br/>0x1: 2 个系统周期<br/>0x2: 3 个系统周期<br/>0x3: 4 个系统周期 (推荐配置)</p> | RW | 0x0 |
| 3:2 | OPMLDOCNT   | <p>低功耗 Sleep Mode 流程打开主 LDO 延迟时间配置</p> <p>低功耗模式进入之前必须将系统时钟切换成低速的 64KHz 的 RC，所以延迟时间=n*T64k</p> <p>0x0: 1 个系统周期<br/>0x1: 2 个系统周期<br/>0x2: 3 个系统周期<br/>0x3: 4 个系统周期 (推荐配置)</p>           | RW | 0x0 |
| 1:0 | CLSMMLDOCNT | <p>低功耗 Sleep Mode 流程关闭主 LDO 延迟时间配置</p> <p>低功耗模式进入之前必须将系统时钟切换成低速的 64KHz 的 RC，所以延迟时间=n*T64k</p> <p>0x0: 1 个系统周期<br/>0x1: 2 个系统周期<br/>0x2: 3 个系统周期<br/>0x3: 4 个系统周期 (推荐配置)</p>           | RW | 0x0 |

### 7.3.5. SYS\_CON4

Addr = 0x0C (XSFR)

| Bit(s) | Name     | Description                                     | R/W | Reset |
|--------|----------|-------------------------------------------------|-----|-------|
| 7      | P07DBSEN | <p>P07 输入滤波功能使能位</p> <p>0x0: 关闭<br/>0x1: 打开</p> | RW  | 0x0   |
| 6      | P06DBSEN | <p>P06 输入滤波功能使能位</p> <p>0x0: 关闭</p>             | RW  | 0x0   |

|   |          |                                     |    |     |
|---|----------|-------------------------------------|----|-----|
|   |          | 0x1: 打开                             |    |     |
| 5 | P05DBSEN | P05 输入滤波功能使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 4 | P04DBSEN | P04 输入滤波功能使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 3 | P03DBSEN | P03 输入滤波功能使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 2 | P02DBSEN | P02 输入滤波功能使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 1 | P01DBSEN | P01 输入滤波功能使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 0 | P00DBSEN | P00 输入滤波功能使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |

### 7.3.6. SYS\_CON5

Addr = 0x0D (XSFR)

| Bit(s) | Name     | Description                         | R/W | Reset |
|--------|----------|-------------------------------------|-----|-------|
| 7:6    | -        | -                                   | -   | -     |
| 5      | P15DBSEN | P15 输入滤波功能使能位<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 4      | P14DBSEN | P14 输入滤波功能使能位<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |

|   |          |                                     |    |     |
|---|----------|-------------------------------------|----|-----|
| 3 | P13DBSEN | P13 输入滤波功能使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 2 | P12DBSEN | P12 输入滤波功能使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 1 | P11DBSEN | P11 输入滤波功能使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 0 | P10DBSEN | P10 输入滤波功能使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |

### 7.3.7. CLK\_CON0

Addr = 0x10 (XSFR)

| Bit(s) | Name        | Description                                                                             | R/W | Reset |
|--------|-------------|-----------------------------------------------------------------------------------------|-----|-------|
| 7      | -           | -                                                                                       | -   | -     |
| 6      | CMPDBSSEL   | 比较器滤波时钟选择位<br>0x0: 选择 eflash_clk<br>0x1: 选择 sys_clk                                     | RW  | 0x0   |
| 5:4    | PODBSCLKSEL | P0 滤波时钟选择位<br>0x0: 选择 hirc_div_clk<br>0x1: 选择 xoscm<br>0x2: 选择 sys_clk<br>0x3: 选择 rc64k | RW  | 0x0   |
| 3:2    | CLKTOIOSEL  | I0 输出时钟源选择位<br>0x0: 选择 sys_clk<br>0x1: 选择 hirc_div_clk<br>0x2: 选择 lirc<br>0x3: 选择 xoscm | RW  | 0x0   |
| 1:0    | SYSCLKSEL   | 系统时钟选择位                                                                                 | RW  | 0x0   |

|  |  |                                                                            |  |  |
|--|--|----------------------------------------------------------------------------|--|--|
|  |  | 0x0: 选择 rc64k<br>0x1: 选择 xoscm<br>0x2: 选择 hirc_div_clk<br>0x3: 选择 hirc_clk |  |  |
|--|--|----------------------------------------------------------------------------|--|--|

### 7.3.8. CLK\_CON1

Addr = 0x11 (XSFR)

| Bit(s) | Name        | Description                                                                                                     | R/W | Reset |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------|-----|-------|
| 7:6    | P1DBSCLKSEL | P1 滤波时钟选择位<br><br>0x0: 选择 hirc_div_clk<br>0x1: 选择 xoscm<br>0x2: 选择 sys_clk<br>0x3: 选择 rc64k                     | RW  | 0x0   |
| 5:3    | HIRCCLKDIV  | 高速 HRCOSC 时钟源分频设置<br><br>配置比为 n+1 时钟<br><br>0x0: 不分频<br>0x1: 2 分频<br>0x2: 3 分频<br>.....<br>0x6: 7 分频<br>0x7: 关闭 | RW  | 0x6   |
| 2:0    | CLKTOIODIV  | I0 输出时钟源分频设置<br><br>配置比为 n+1 时钟<br><br>0x0: 不分频<br>0x1: 2 分频<br>0x2: 3 分频<br>.....<br>0x6: 7 分频<br>0x7: 关闭      | RW  | 0x0   |

### 7.3.9. CLK\_CON2

Addr = 0x12 (XSFR)

| Bit(s) | Name      | Description                                                                                     | R/W | Reset |
|--------|-----------|-------------------------------------------------------------------------------------------------|-----|-------|
| 7:4    | -         | -                                                                                               | -   | -     |
| 3:0    | SYSCLKDIV | 系统时钟分频设置<br>配置比为 n+1 时钟<br>0x0: 不分频<br>0x1: 2 分频<br>0x2: 3 分频<br>.....<br>0xE: 15 分频<br>0xF: 关闭 | RW  | 0x0   |

### 7.3.10. CLK\_CON3

Addr = 0x13 (XSFR)

| Bit(s) | Name      | Description                                 | R/W | Reset |
|--------|-----------|---------------------------------------------|-----|-------|
| 7      | TMR2CLKEN | 基本 Timer2 模块时钟使能位<br>0x0: 关闭时钟<br>0x1: 打开时钟 | RW  | 0x1   |
| 6      | TMR1CLKEN | 基本 Timer1 模块时钟使能位<br>0x0: 关闭时钟<br>0x1: 打开时钟 | RW  | 0x1   |
| 5      | TMROCLKEN | 基本 Timer0 模块时钟使能位<br>0x0: 关闭时钟<br>0x1: 打开时钟 | RW  | 0x1   |
| 4      | CRCCLKEN  | CRC 模块时钟使能位<br>0x0: 关闭时钟<br>0x1: 打开时钟       | RW  | 0x1   |
| 3      | I2CCLKEN  | I2C 模块时钟使能位<br>0x0: 关闭时钟                    | RW  | 0x1   |

|   |            |                                                |    |     |
|---|------------|------------------------------------------------|----|-----|
|   |            | 0x1: 打开时钟                                      |    |     |
| 2 | -          | -                                              | RW | 0x1 |
| 1 | UART1CLKEN | <b>UART1 模块时钟使能位</b><br>0x0: 关闭时钟<br>0x1: 打开时钟 | RW | 0x1 |
| 0 | UARTOCLKEN | <b>UART0 模块时钟使能位</b><br>0x0: 关闭时钟<br>0x1: 打开时钟 | RW | 0x1 |

### 7.3.11. CLK\_CON4

Addr = 0x14 (XSFR)

| Bit(s) | Name        | Description                                 | R/W | Reset |
|--------|-------------|---------------------------------------------|-----|-------|
| 7      | TESTCLKEN   | 测试时钟使能位<br>0x0: 关闭时钟<br>0x1: 打开时钟           | RW  | 0x0   |
| 6      | -           | -                                           | -   | -     |
| 5      | RAMCLKEN    | 片上 SRAM 时钟使能位<br>0x0: 关闭时钟<br>0x1: 打开时钟     | RW  | 0x1   |
| 4      | CMPDBSCLKEN | 比较器 debouce 时钟使能位<br>0x0: 关闭时钟<br>0x1: 打开时钟 | RW  | 0x1   |
| 3:2    | -           | -                                           | -   | -     |
| 1      | STMR2CLKEN  | 高级 Timer2 模块时钟使能位<br>0x0: 关闭时钟<br>0x1: 打开时钟 | RW  | 0x1   |
| 0      | STMR1CLKEN  | 高级 Timer1 模块时钟使能位<br>0x0: 关闭时钟<br>0x1: 打开时钟 | RW  | 0x1   |

### 7.3.12. CLK\_CON5

Addr = 0x15 (XSFR)

| Bit(s) | Name         | Description                                                                                    | R/W | Reset |
|--------|--------------|------------------------------------------------------------------------------------------------|-----|-------|
| 7:6    | -            | -                                                                                              | -   | -     |
| 5:4    | TMR2CLKSEL   | 基本 Timer2 模块时钟选择位<br>0x0: 选择 sys_clk<br>0x1: 选择 xoscm<br>0x2: 选择 hirc_div_clk<br>0x3: 选择 rc64k | RW  | 0x0   |
| 3:2    | LVDDBSCLKSEL | LVD 模块滤波时钟源选择位<br>0x0: 选择 sys_clk<br>0x1: 选择 hirc_div_clk<br>0x2: 选择 xoscm<br>0x3: 选择 rc64k    | RW  | 0x0   |
| 1      | -            | -                                                                                              | -   | -     |
| 0      | TCLKEN       | 测试时钟 1 使能位<br>0x0: 关闭时钟<br>0x1: 打开时钟                                                           | RW  | 0x1   |

### 7.3.13. CLK\_CON6

Addr = 0x16 (XSFR)

| Bit(s) | Name    | Description                                                                                 | R/W | Reset |
|--------|---------|---------------------------------------------------------------------------------------------|-----|-------|
| 7:6    | -       | -                                                                                           | -   | -     |
| 5:0    | MCLKDIV | 存储器烧写时钟分频设置<br>配置比为 n+1 时钟<br>0x00: 不分频<br>0x01: 2 分频<br>0x02: 3 分频<br>.....<br>0x3E: 63 分频 | RW  | 0x0   |

|  |  |          |  |  |
|--|--|----------|--|--|
|  |  | 0x3F: 关闭 |  |  |
|--|--|----------|--|--|

### 7.3.14. AIP\_CON0

Addr = 0x30 (XSFR)

| Bit(s) | Name  | Description                                              | R/W | Reset |
|--------|-------|----------------------------------------------------------|-----|-------|
| 7      | HRCEN | HRC 时钟使能信号<br>0x0: 关闭<br>0x1: 打开                         | RW  | 0x0   |
| 6:0    | HRCSC | HRC 时钟频率细调 (step=1%)<br>0x00: low<br>.....<br>0x7F: high | RW  | 0x48  |

### 7.3.15. AIP\_CON1

Addr = 0x31 (XSFR)

| Bit(s) | Name           | Description                                                    | R/W | Reset |
|--------|----------------|----------------------------------------------------------------|-----|-------|
| 7      | -              | -                                                              | -   | -     |
| 6:5    | HRCSCADD_B2TQ1 | HRC 时钟频率细调的高 2 位 (step=0.5%)<br>0x0: low<br>.....<br>0x3: high | RW  | 0x1   |
| 4      | HRCTESTEN      | HRC 内部模拟电压测试使能信号<br>0x0: 关闭<br>0x1: 打开                         | RW  | 0x0   |
| 3      | XOSCEN         | 晶振的使能信号<br>0x0: 关闭<br>0x1: 打开                                  | RW  | 0x0   |
| 2      | XOSCHY         | 输出时钟迟滞窗口选择<br>0x0: 没有迟滞<br>0x1: 有+-10%的迟滞                      | RW  | 0x1   |

|   |             |                                        |    |     |
|---|-------------|----------------------------------------|----|-----|
| 1 | HRCSCADD_B0 | HRC 时钟频率细调的低 1 位 (step=0.5%)           | RW | 0x0 |
| 0 | HRCMR       | HRC 时钟频率粗调<br>0x0: 16MHz<br>0x1: 32MHz | RW | 0x1 |

### 7.3.16. AIP\_CON2

Addr = 0x32 (XSFR)

| Bit(s) | Name | Description | R/W | Reset |
|--------|------|-------------|-----|-------|
| 7:0    | -    | -           | RW  | 0x0   |

### 7.3.17. AIP\_CON3

Addr = 0x33 (XSFR)

| Bit(s) | Name | Description | R/W | Reset |
|--------|------|-------------|-----|-------|
| 7:0    | -    | -           | RW  | 0x0   |

### 7.3.18. AIP\_CON4

Addr = 0x34 (XSFR)

| Bit(s) | Name | Description | R/W | Reset |
|--------|------|-------------|-----|-------|
| 7:0    | -    | -           | -   | -     |

### 7.3.19. IO\_MAP

Addr = 0x28 (XSFR)

| Bit(s) | Name    | Description                                            | R/W | Reset |
|--------|---------|--------------------------------------------------------|-----|-------|
| 7      | WKUPIN3 | GPIO wakeup 通道 3 输入引脚选择<br>0x0: 不选择 P13<br>0x1: 选择 P13 | RW  | 0x0   |

|     |            |                                                                                                                                  |    |     |
|-----|------------|----------------------------------------------------------------------------------------------------------------------------------|----|-----|
| 6   | WKUPIN2    | GPIO wakeup 通道 2 输入引脚选择<br>0x0: 不选择 P12<br>0x1: 选择 P12                                                                           | RW | 0x0 |
| 5   | WKUPIN1    | GPIO wakeup 通道 1 输入引脚选择<br>0x0: 不选择 P10<br>0x1: 选择 P10                                                                           | RW | 0x0 |
| 4   | WKUPINO    | GPIO wakeup 通道 0 输入引脚选择<br>0x0: 不选择 P07<br>0x1: 选择 P07                                                                           | RW | 0x0 |
| 3:2 | CLKTOIOMAP | IO 输出时钟源功能 pin 脚选择位<br>0x0: 关闭 IO 输出时钟功能<br>0x1: 选择 P04 输出时钟<br>0x2: 选择 P05 输出时钟<br>0x3: 选择 P12 输出时钟                             | RW | 0x0 |
| 1:0 | ISPMAP     | 烧写/调试 pin 脚选择位<br>0x0: 关闭烧写/调试功能<br>0x1: 选择 P10【ISP_CLK】 , P07【ISP_DAT】<br>0x2: 选择 P00【ISP_CLK】 , P01【ISP_DAT】<br>0x3: 关闭烧写/调试功能 | RW | 0x1 |

### 7.3.20. IO\_MAP1

Addr = 0x2A (XSFR)

| Bit(s) | Name        | Description                                                          | R/W | Reset |
|--------|-------------|----------------------------------------------------------------------|-----|-------|
| 7      | MEMDVSE     | 片上 SRAM 动态电压调整值使能位<br><br><b>Note:</b> 用户千万不要配置该寄存器，否则会导致芯片不确定行为！！！！ | RW  | 0x0   |
| 6:5    | MEMDVS[3:2] | 片上 SRAM 动态电压调整值<br><br><b>Note:</b> 用户千万不要配置该寄存器，否则会导致芯片不确定行为！！！！    | RW  | 0x0   |
| 4      | RSTBEN      | RSTB 复位功能使能位<br>0x0: 关闭 RSTB 复位功能<br>0x1: 打开 RSTB 复位功能               | RW  | 0x0   |

|     |         |                                                                                                                                                                   |    |     |
|-----|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|
| 3:2 | MPDNCNT | 低功耗 Sleep Mode 流程进入关闭程序存储器供电的延迟时间配置<br><br>低功耗模式进入之前必须将系统时钟切换成低速的 64KHz 的 RC，所以延迟时间=n*T64k。<br>0x0: 1 个系统周期<br>0x1: 2 个系统周期<br>0x2: 3 个系统周期<br>0x3: 4 个系统周期（推荐配置） | RW | 0x0 |
| 1:0 | -       | -                                                                                                                                                                 | RW | 0x0 |

### 7.3.21. WKUP\_CON0

Addr = 0xAB (SFR)

| Bit(s) | Name     | Description                                                | R/W | Reset |
|--------|----------|------------------------------------------------------------|-----|-------|
| 7      | WKUP3EDG | 低功耗模式 wakeup 通道 3 输入触发边沿设置<br>0x0: 上升沿触发唤醒<br>0x1: 下降沿触发唤醒 | RW  | 0x0   |
| 6      | WKUP2EDG | 低功耗模式 wakeup 通道 2 输入触发边沿设置<br>0x0: 上升沿触发唤醒<br>0x1: 下降沿触发唤醒 | RW  | 0x0   |
| 5      | WKUP1EDG | 低功耗模式 wakeup 通道 1 输入触发边沿设置<br>0x0: 上升沿触发唤醒<br>0x1: 下降沿触发唤醒 | RW  | 0x0   |
| 4      | WKUPOEDG | 低功耗模式 wakeup 通道 0 输入触发边沿设置<br>0x0: 上升沿触发唤醒<br>0x1: 下降沿触发唤醒 | RW  | 0x0   |
| 3      | WKUP3EN  | 低功耗模式 wakeup 通道 3 功能使能位<br>0x0: 关闭<br>0x1: 打开              | RW  | 0x0   |
| 2      | WKUP2EN  | 低功耗模式 wakeup 通道 2 功能使能位<br>0x0: 关闭<br>0x1: 打开              | RW  | 0x0   |

|   |         |                                               |    |     |
|---|---------|-----------------------------------------------|----|-----|
| 1 | WKUP1EN | 低功耗模式 wakeup 通道 1 功能使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 0 | WKUPOEN | 低功耗模式 wakeup 通道 0 功能使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |

### 7.3.22. WKUP\_PND

Addr = 0xAC (SFR)

| Bit(s) | Name      | Description                                                        | R/W | Reset |
|--------|-----------|--------------------------------------------------------------------|-----|-------|
| 7      | WKUP3PCLR | 低功耗模式 wakeup 通道 3 清 pending 位<br>0x0: 无操作<br>0x1: 清 pending        | RW  | 0x0   |
| 6      | WKUP2PCLR | 低功耗模式 wakeup 通道 2 清 pending 位<br>0x0: 无操作<br>0x1: 清 pending        | RW  | 0x0   |
| 5      | WKUP1PCLR | 低功耗模式 wakeup 通道 1 清 pending 位<br>0x0: 无操作<br>0x1: 清 pending        | RW  | 0x0   |
| 4      | WKUPOPCLR | 低功耗模式 wakeup 通道 0 清 pending 位<br>0x0: 无操作<br>0x1: 清 pending        | RW  | 0x0   |
| 3      | WKUP3PND  | 低功耗模式 wakeup 通道 3 唤醒 pending 位<br>0x0: 无 pending<br>0x1: 有 pending | RW  | 0x0   |
| 2      | WKUP2PND  | 低功耗模式 wakeup 通道 2 唤醒 pending 位<br>0x0: 无 pending<br>0x1: 有 pending | RW  | 0x0   |
| 1      | WKUP1PND  | 低功耗模式 wakeup 通道 1 唤醒 pending 位<br>0x0: 无 pending<br>0x1: 有 pending | RW  | 0x0   |
| 0      | WKUPOPND  | 低功耗模式 wakeup 通道 0 唤醒 pending 位                                     | RW  | 0x0   |

|  |  |                                  |  |  |
|--|--|----------------------------------|--|--|
|  |  | 0x0: 无 pending<br>0x1: 有 pending |  |  |
|--|--|----------------------------------|--|--|

### 7.3.23. LP\_CON

Addr = 0xBE (SFR)

| Bit(s) | Name      | Description                                                                                                                                                                                                                                   | R/W | Reset |
|--------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7      | IDLE      | <b>Idle 低功耗模式使能</b><br>0x0: 关闭<br>0x1: 打开, 进入 Idle 低功耗模式                                                                                                                                                                                      | RW  | 0x1   |
| 6      | SLEEPGOEN | <b>Sleep 低功耗模式唤醒后继续跑后续程序使能位</b><br>0x0: Sleep 模式唤醒后复位重新跑程序<br>0x1: Sleep 模式唤醒后继续跑后续程序                                                                                                                                                         | RW  | 0x1   |
| 5      | CPDIS     | <b>用户程序保护功能关闭位</b><br>CPU 和 ISD 都无法写寄存器<br>0x0: 打开 (默认状态)<br>0x1: 关闭                                                                                                                                                                          | RO  | 0x0   |
| 4      | LPGLIRCEN | <b>低功耗进入低速 RC 选择</b><br>低功耗 Sleep 模式下, 可以通过配置该寄存器为 1, 在系统进入 Sleep 模式后自动 gate 住 RC64K 低速时钟, 目的是减少 Sleep 的漏电功耗。也可以选择不关闭 RC64K.<br><b>Note:</b> 该功能只能在 Sleep 低功耗模式下, 由 GPIO 唤醒系统的场景下才能使用该功能。如果是 TIMER2 定时唤醒场景下不可以关闭该时钟, 造成 TIMER2 没有工作时钟而不能唤醒系统。 | RW  | 0x0   |
| 3      | CMCEDIS   | <b>程序存储器空片硬件自动检查功能关闭位</b><br>默认芯片上电以后会自动检查程序存储器是否有烧写程序, 如果没有烧写程序, 则 hold 住 cpu 不跑任何程序。<br>0x0: 开启空片自动检查功能<br>0x1: 关闭空片自动检查功能                                                                                                                  | RW  | 0x0   |
| 2      | TMHCPU    | <b>测试模式下 hold 住 CPU 使能</b>                                                                                                                                                                                                                    | RW  | 0x0   |

|   |       |                                                                                 |    |     |
|---|-------|---------------------------------------------------------------------------------|----|-----|
|   |       | <b>Note:</b> 用户程序不要随便写这个寄存器，会造成系统功能异常的风险！！！<br>0x0: 不 hold CPU<br>0x1: hold CPU |    |     |
| 1 | STOP  | Stop 低功耗模式使能<br>0x0: 关闭<br>0x1: 打开，进入 Stop 低功耗模式                                | RW | 0x0 |
| 0 | SLEEP | Sleep 低功耗模式使能<br>0x0: 关闭<br>0x1: 打开，进入 Sleep 低功耗模式                              | RW | 0x0 |

### 7.3.24. SYS\_PND

Addr = 0xBF (SFR)

| Bit(s) | Name      | Description            | R/W | Reset |
|--------|-----------|------------------------|-----|-------|
| 7:6    | -         | -                      | -   | -     |
| 5      | SLPSTACLR | 写 1 清掉系统 sleep 标志位     | RW  | 0x0   |
| 4      | SFTRSTCLR | 写 1 清掉系统软复位标志位         | RW  | 0x0   |
| 3:2    | -         | -                      | -   | -     |
| 1      | SLPPND    | 系统 sleep 标志位           | RW  | 0x0   |
| 0      | SFTRSTPND | 系统软复位标志位<br>写 1 系统软复位。 | RW  | 0x0   |

## 8. 中断系统

### 8.1. 中断概述

TX8W7010 支持多达 14 个中断源。每个中断源都有独立的中断使能信号，可以通过软件来控制其使能开关。中断控制器有以下特性：

- 从 14 个中断源接收中断

- 每个中断有固定的中断号，中断号越小优先级越高
- 中断延时：5~8 机器周期

## 8.2. 结构框图



图 8-1 中断结构图

### 8.3. 中断向量表

中断控制器支持 14 个中断源。当中断发生且中断使能之后，跳转到对应向量地址去执行 LCALL 指令来进入中断服务程序。

表 8-1 中断向量表

| 中断源          | 中断等级 | 中断号 | 中断地址  | 说明         |
|--------------|------|-----|-------|------------|
| LVD          | 低    | 0   | 0003H | 低压检测       |
| P0           | 低    | 1   | 0006H | P0 端口中断    |
| P1           | 低    | 2   | 0009H | P1 端口中断    |
| TMRO         | 低    | 3   | 000CH | TMRO 中断    |
| TMR1         | 低    | 4   | 000FH | TMR1 中断    |
| TMR2         | 低    | 5   | 0012H | TMR2 中断    |
| STMR1        | 低    | 6   | 0015H | STMR1 中断   |
| STMR2        | 低    | 7   | 0018H | STMR2 中断   |
| -            | 低    | 8   | 001BH | -          |
| COMP         | 低    | 9   | 001EH | 模拟比较器中断    |
| I2C          | 低    | 10  | 0021H | I2C 状态中断   |
| UART0        | 低    | 11  | 0024H | UART0 状态中断 |
| UART1        | 低    | 12  | 0027H | UART1 状态中断 |
| -            | 低    | 13  | 002AH | -          |
| WDT/WKUP_PND | 低    | 14  | 002DH | 看门狗中断      |

### 8.4. 寄存器列表

表 8-2 中断寄存器列表

| Address    | Register Name | Description                   |
|------------|---------------|-------------------------------|
| 0xA8 (SFR) | IE0           | Interrupt Enable 0 Register   |
| 0xA9 (SFR) | IE1           | Interrupt Enable 1 Register   |
| 0xB8 (SFR) | IP0           | Interrupt Priority 0 Register |
| 0xB9 (SFR) | IP1           | Interrupt Priority 1 Register |

## 8.5. 寄存器详细说明

### 8.5.1. IE0

Addr = 0xA8 (SFR)

| Bit(s) | Name  | Description                                             | R/W | Reset |
|--------|-------|---------------------------------------------------------|-----|-------|
| 7      | EA    | 全局中断使能<br>0x0: 禁止所有中断<br>0x1: 允许所有未被屏蔽的中断               | RW  | 0x0   |
| 6      | STMR1 | STMR1 中断使能<br>0x0: 禁止 STMR1 中断<br>0x1: 允许 STMR1 未被屏蔽的中断 | RW  | 0x0   |
| 5      | TMR2  | TMR2 中断使能<br>0x0: 禁止 TMR2 中断<br>0x1: 允许 TMR2 未被屏蔽的中断    | RW  | 0x0   |
| 4      | TMR1  | TMR1 中断使能<br>0x0: 禁止 TMR1 中断<br>0x1: 允许 TMR1 未被屏蔽的中断    | RW  | 0x0   |
| 3      | TMRO  | TMRO 中断使能<br>0x0: 禁止 TMRO 中断<br>0x1: 允许 TMRO 未被屏蔽的中断    | RW  | 0x0   |
| 2      | GPI01 | GPI01 中断使能<br>0x0: 禁止 GPI01 中断<br>0x1: 允许 GPI01 未被屏蔽的中断 | RW  | 0x0   |

|   |       |                                                                |    |     |
|---|-------|----------------------------------------------------------------|----|-----|
| 1 | GPIO0 | <b>GPIO0 中断使能</b><br>0x0: 禁止 GPIO0 中断<br>0x1: 允许 GPIO0 未被屏蔽的中断 | RW | 0x0 |
| 0 | LVD   | <b>LVD 中断使能</b><br>0x0: 禁止 LVD 中断<br>0x1: 允许 LVD 未被屏蔽的中断       | RW | 0x0 |

### 8.5.2. IE1

Addr = 0xA9 (SFR)

| Bit(s) | Name     | Description                                                             | R/W | Reset |
|--------|----------|-------------------------------------------------------------------------|-----|-------|
| 7      | WDT/WKUP | <b>WDT/WKUP 中断使能</b><br>0x0: 禁止 WDT/WKUP 中断<br>0x1: 允许 WDT/WKUP 未被屏蔽的中断 | RW  | 0x0   |
| 6      | -        | -                                                                       | RW  | 0x0   |
| 5      | UART1    | <b>UART1 中断使能</b><br>0x0: 禁止 UART1 中断<br>0x1: 允许 UART1 未被屏蔽的中断          | RW  | 0x0   |
| 4      | UART0    | <b>UART0 中断使能</b><br>0x0: 禁止 UART0 中断<br>0x1: 允许 UART0 未被屏蔽的中断          | RW  | 0x0   |
| 3      | I2C      | <b>I2C 中断使能</b><br>0x0: 禁止 I2C 中断<br>0x1: 允许 I2C 未被屏蔽的中断                | RW  | 0x0   |
| 2      | COMP     | <b>比较器中断使能</b><br>0x0: 禁止比较器中断<br>0x1: 允许比较器未被屏蔽的中断                     | RW  | 0x0   |
| 1      | -        | -                                                                       | RW  | 0x0   |
| 0      | STMR2    | <b>STMR2 中断使能</b><br>0x0: 禁止 STMR2 中断<br>0x1: 允许 STMR2 未被屏蔽的中断          | RW  | 0x0   |

### 8.5.3. IP0

Addr = 0xB8 (SFR)

| Bit(s) | Name  | Description                                 | R/W | Reset |
|--------|-------|---------------------------------------------|-----|-------|
| 7      | -     | -                                           | -   | -     |
| 6      | STMR1 | STMR1 中断优先级<br>0x0: 优先等级为 0<br>0x1: 优先等级为 1 | RW  | 0x0   |
| 5      | TMR2  | TMR2 中断优先级<br>0x0: 优先等级为 0<br>0x1: 优先等级为 1  | RW  | 0x0   |
| 4      | TMR1  | TMR1 中断优先级<br>0x0: 优先等级为 0<br>0x1: 优先等级为 1  | RW  | 0x0   |
| 3      | TMRO  | TMRO 中断优先级<br>0x0: 优先等级为 0<br>0x1: 优先等级为 1  | RW  | 0x0   |
| 2      | GPI01 | GPI01 中断优先级<br>0x0: 优先等级为 0<br>0x1: 优先等级为 1 | RW  | 0x0   |
| 1      | GPI00 | GPI00 中断优先级<br>0x0: 优先等级为 0<br>0x1: 优先等级为 1 | RW  | 0x0   |
| 0      | LVD   | LVD 中断优先级<br>0x0: 优先等级为 0<br>0x1: 优先等级为 1   | RW  | 0x0   |

### 8.5.4. IP1

Addr = 0xB9 (SFR)

| Bit(s) | Name     | Description    | R/W | Reset |
|--------|----------|----------------|-----|-------|
| 7      | WDT/WKUP | WDT/WKUP 中断优先级 | RW  | 0x0   |

|   |       |                                                    |    |     |
|---|-------|----------------------------------------------------|----|-----|
|   |       | 0x0: 优先等级为 0<br>0x1: 优先等级为 1                       |    |     |
| 6 | -     | -                                                  | RW | 0x0 |
| 5 | UART1 | <b>UART1 中断优先级</b><br>0x0: 优先等级为 0<br>0x1: 优先等级为 1 | RW | 0x0 |
| 4 | UART0 | <b>UART0 中断优先级</b><br>0x0: 优先等级为 0<br>0x1: 优先等级为 1 | RW | 0x0 |
| 3 | I2C   | <b>I2C 中断优先级</b><br>0x0: 优先等级为 0<br>0x1: 优先等级为 1   | RW | 0x0 |
| 2 | COMP  | <b>比较器中断优先级</b><br>0x0: 优先等级为 0<br>0x1: 优先等级为 1    | RW | 0x0 |
| 1 | -     | -                                                  | RW | 0x0 |
| 0 | STMR2 | <b>STMR2 中断优先级</b><br>0x0: 优先等级为 0<br>0x1: 优先等级为 1 | RW | 0x0 |

## 8.6. 中断优先级及中断嵌套

芯片规定 2 个中断优先级，可实现 2 级中断嵌套。当一个中断已经响应，若有高级别中断发出请求，后者可以中断前者，实现中断嵌套。每个中断可配置优先等级 0-1。中断优先级越大，中断的优先级越高。同一年级没有嵌套，采用时间优先的原则，先到先执行。

## 9. I/O 端口

### 9.1. 结构框图



图 9-1 IO 结构图

### 9.2. 寄存器列表

表 9-1 GPIO 寄存器列表

| Address     | Register Name | Description                  |
|-------------|---------------|------------------------------|
| 0x80 (SFR)  | P0            | P0 data register             |
| 0x50 (XSFR) | P0_PU         | P0 pull-up enable register   |
| 0x51 (XSFR) | P0_PD         | P0 pull-down enable register |
| 0x52 (XSFR) | P0_MDO        | P0 mode register 0           |
| 0x53 (XSFR) | P0_MD1        | P0 mode register 1           |

|             |          |                                        |
|-------------|----------|----------------------------------------|
| 0x54 (XSFR) | P0_AF0   | P0 alternal function config register 0 |
| 0x55 (XSFR) | P0_AF1   | P0 alternal function config register 1 |
| 0x56 (XSFR) | P0_TRG0  | P0 interrupt trigger config register 0 |
| 0x57 (XSFR) | P0_TRG1  | P0 interrupt trigger config register 1 |
| 0x58 (XSFR) | P0_PND   | P0 interrupt pending register          |
| 0x59 (XSFR) | P0_IMK   | P0 interrupt mask register             |
| 0x5A (XSFR) | P0_AIOEN | P0 analog function enable register     |
| 0x5B (XSFR) | P0_DRV   | P0 driving current config register     |
| 0x5C (XSFR) | P0_OD    | P0 open-drain enable register          |
| 0x90 (SFR)  | P1       | P1 data register                       |
| 0x60 (XSFR) | P1_PU    | P1 pull-up enable register             |
| 0x61 (XSFR) | P1_PD    | P1 pull-down enable register           |
| 0x62 (XSFR) | P1_MDO   | P1 mode register 0                     |
| 0x63 (XSFR) | P1_MD1   | P1 mode register 1                     |
| 0x64 (XSFR) | P1_AF0   | P1 alternal function config register 0 |
| 0x65 (XSFR) | P1_AF1   | P1 alternal function config register 1 |
| 0x66 (XSFR) | P1_TRG0  | P1 interrupt trigger config register 0 |
| 0x67 (XSFR) | P1_TRG1  | P1 interrupt trigger config register 1 |
| 0x68 (XSFR) | P1_PND   | P1 interrupt pending register          |
| 0x69 (XSFR) | P1_IMK   | P1 interrupt mask register             |
| 0x6A (XSFR) | P1_AIOEN | P1 analog function enable register     |
| 0x6B (XSFR) | P1_DRV   | P1 driving current config register     |
| 0x6C (XSFR) | P1_OD    | P1 open-drain enable register          |

### 9.3. 寄存器详细说明

#### 9.3.1. P0

Addr = 0x80 (SFR)

| Bit(s) | Name | Description | R/W | Reset |
|--------|------|-------------|-----|-------|
| 7:0    | P0   | P0 数据寄存器    | RW  | 0x00  |

#### 9.3.2. P0\_PU

Addr = 0x50 (XSFR)

| Bit(s) | Name  | Description                                | R/W | Reset |
|--------|-------|--------------------------------------------|-----|-------|
| 7      | P07PU | P07 上拉电阻 (30K) 使能控制位<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 6      | P06PU | P06 上拉电阻 (30K) 使能控制位<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 5      | P05PU | P05 上拉电阻 (30K) 使能控制位<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 4      | P04PU | P04 上拉电阻 (30K) 使能控制位<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 3      | P03PU | P03 上拉电阻 (30K) 使能控制位<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 2      | P02PU | P02 上拉电阻 (30K) 使能控制位<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 1      | P01PU | P01 上拉电阻 (30K) 使能控制位<br>0x0: 关闭            | RW  | 0x0   |

|   |       |                                            |    |     |
|---|-------|--------------------------------------------|----|-----|
|   |       | 0x1: 打开                                    |    |     |
| 0 | P00PU | P00 上拉电阻 (30K) 使能控制位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |

### 9.3.3. P0\_PD

Addr = 0x51 (XSFR)

| Bit(s) | Name  | Description                                | R/W | Reset |
|--------|-------|--------------------------------------------|-----|-------|
| 7      | P07PD | P07 下拉电阻 (30K) 使能控制位<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 6      | P06PD | P06 下拉电阻 (30K) 使能控制位<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 5      | P05PD | P05 下拉电阻 (30K) 使能控制位<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 4      | P04PD | P04 下拉电阻 (30K) 使能控制位<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 3      | P03PD | P03 下拉电阻 (30K) 使能控制位<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 2      | P02PD | P02 下拉电阻 (30K) 使能控制位<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 1      | P01PD | P01 下拉电阻 (30K) 使能控制位<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 0      | P00PD | P00 下拉电阻 (30K) 使能控制位<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |

### 9.3.4. P0\_MD0

Addr = 0x52 (XSFR)

| Bit(s) | Name  | Description                                                                                                                                              | R/W | Reset |
|--------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7:6    | P03MD | P03 模式配置位<br>0x0: 输入模式<br>0x1: 输出模式<br>0x2: 多功能 IO 模式<br>0x3: 模拟 IO 模式                                                                                   | RW  | 0x0   |
| 5:4    | P02MD | P02 模式配置位<br>0x0: 输入模式<br>0x1: 输出模式<br>0x2: 多功能 IO 模式<br>0x3: 模拟 IO 模式                                                                                   | RW  | 0x0   |
| 3:2    | P01MD | P01 模式配置位<br>0x0: 输入模式<br>0x1: 输出模式<br>0x2: 多功能 IO 模式<br>0x3: 模拟 IO 模式<br><br><b>Note:</b> 如果烧录口为 P01，则需要对应将 IO_MAP[0:1]，即 ISPMAP 设置为 0x03，才能切换为 GPIO 功能 | RW  | 0x0   |
| 1:0    | P00MD | P00 模式配置位<br>0x0: 输入模式<br>0x1: 输出模式<br>0x2: 多功能 IO 模式<br>0x3: 模拟 IO 模式<br><br><b>Note:</b> 如果烧录口为 P00，则需要对应将 IO_MAP[0:1]，即 ISPMAP 设置为 0x03，才能切换为 GPIO 功能 | RW  | 0x0   |

### 9.3.5. P0\_MD1

Addr = 0x53 (XSFR)

| Bit(s) | Name  | Description                                                                                                                                                 | R/W | Reset |
|--------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7:6    | P07MD | <b>P07 模式配置位</b><br>0x0: 输入模式<br>0x1: 输出模式<br>0x2: 多功能 IO 模式<br>0x3: 模拟 IO 模式<br><b>Note:</b> 如果烧录口为 P07，则需要对应将 IO_MAP[0:1]，即 ISPMAP 设置为 0x03，才能切换为 GPIO 功能 | RW  | 0x0   |
| 5:4    | P06MD | <b>P06 模式配置位</b><br>0x0: 输入模式<br>0x1: 输出模式<br>0x2: 多功能 IO 模式<br>0x3: 模拟 IO 模式                                                                               | RW  | 0x0   |
| 3:2    | P05MD | <b>P05 模式配置位</b><br>0x0: 输入模式<br>0x1: 输出模式<br>0x2: 多功能 IO 模式<br>0x3: 模拟 IO 模式                                                                               | RW  | 0x0   |
| 1:0    | P04MD | <b>P04 模式配置位</b><br>0x0: 输入模式<br>0x1: 输出模式<br>0x2: 多功能 IO 模式<br>0x3: 模拟 IO 模式                                                                               | RW  | 0x0   |

### 9.3.6. P0\_AF0

Addr = 0x54 (XSFR)

| Bit(s) | Name | Description | R/W | Reset |
|--------|------|-------------|-----|-------|
|        |      |             |     |       |

|     |       |                                                                                                                   |    |     |
|-----|-------|-------------------------------------------------------------------------------------------------------------------|----|-----|
| 7:6 | P03AF | P03 多功能模式下, 功能配置位<br>0x0: STMR1_CHA function<br>0x1: 保留<br>0x2: STMR2_CHB function<br>0x3: PORT_WKUP_IN3 function | RW | 0x0 |
| 5:4 | P02AF | P02 多功能模式下, 功能配置位<br>0x0: STMR1_CHB function<br>0x1: 保留<br>0x2: 保留<br>0x3: PORT_WKUP_IN2 function                 | RW | 0x0 |
| 3:2 | P01AF | P01 多功能模式下, 功能配置位<br>0x0: TMR2_PWM function<br>0x1: UART1_TX function<br>0x2: 保留<br>0x3: PORT_WKUP_IN1 function   | RW | 0x0 |
| 1:0 | P00AF | P00 多功能模式下, 功能配置位<br>0x0: TMR2_PWM function<br>0x1: UART1_RX function<br>0x2: 保留<br>0x3: PORT_WKUP_IN0 function   | RW | 0x0 |

### 9.3.7. P0\_AF1

Addr = 0x55 (XSFR)

| Bit(s) | Name  | Description                                                                                                                  | R/W | Reset |
|--------|-------|------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7:6    | P07AF | P07 多功能模式下, 功能配置位<br>0x0: CMPO_DIG_OUT function<br>0x1: I2C_SDA function<br>0x2: TMR2_PWM function<br>0x3: UART0_RX function | RW  | 0x0   |
| 5:4    | P06AF | P06 多功能模式下, 功能配置位<br>0x0: STMR1_CHB function<br>0x1: TMRO_PWM function                                                       | RW  | 0x0   |

|     |       |                                                                                                                      |    |     |
|-----|-------|----------------------------------------------------------------------------------------------------------------------|----|-----|
|     |       | 0x2: STMR2_CHA function<br>0x3: PORT_WKUP_IN2 function                                                               |    |     |
| 3:2 | P05AF | P05 多功能模式下, 功能配置位<br>0x0: STMR2_CHA function<br>0x1: TMRO_CAP function<br>0x2: 保留<br>0x3: PORT_WKUP_IN1 function     | RW | 0x0 |
| 1:0 | P04AF | P04 多功能模式下, 功能配置位<br>0x0: STMR2_CHB function<br>0x1: CMPO_DIG_OUT function<br>0x2: 保留<br>0x3: PORT_WKUP_IN0 function | RW | 0x0 |

### 9.3.8. P0\_TRG0

Addr = 0x56 (XSFR)

| Bit(s) | Name   | Description                                                                  | R/W | Reset |
|--------|--------|------------------------------------------------------------------------------|-----|-------|
| 7:6    | P03TRG | P03 中断触发源配置位<br>0x0: 上升沿和下降沿触发<br>0x1: 下降沿触发<br>0x2: 上升沿触发<br>0x3: 上升沿和下降沿触发 | RW  | 0x0   |
| 5:4    | P02TRG | P02 中断触发源配置位<br>0x0: 上升沿和下降沿触发<br>0x1: 下降沿触发<br>0x2: 上升沿触发<br>0x3: 上升沿和下降沿触发 | RW  | 0x0   |
| 3:2    | P01TRG | P01 中断触发源配置位<br>0x0: 上升沿和下降沿触发<br>0x1: 下降沿触发<br>0x2: 上升沿触发<br>0x3: 上升沿和下降沿触发 | RW  | 0x0   |
| 1:0    | P00TRG | P00 中断触发源配置位                                                                 | RW  | 0x0   |

|  |  |                                                              |  |  |
|--|--|--------------------------------------------------------------|--|--|
|  |  | 0x0: 上升沿和下降沿触发<br>0x1: 下降沿触发<br>0x2: 上升沿触发<br>0x3: 上升沿和下降沿触发 |  |  |
|--|--|--------------------------------------------------------------|--|--|

### 9.3.9. P0\_TRG1

Addr = 0x57 (XSFR)

| Bit(s) | Name   | Description                                                                  | R/W | Reset |
|--------|--------|------------------------------------------------------------------------------|-----|-------|
| 7:6    | P07TRG | P07 中断触发源配置位<br>0x0: 上升沿和下降沿触发<br>0x1: 下降沿触发<br>0x2: 上升沿触发<br>0x3: 上升沿和下降沿触发 | RW  | 0x0   |
| 5:4    | P06TRG | P06 中断触发源配置位<br>0x0: 上升沿和下降沿触发<br>0x1: 下降沿触发<br>0x2: 上升沿触发<br>0x3: 上升沿和下降沿触发 | RW  | 0x0   |
| 3:2    | P05TRG | P05 中断触发源配置位<br>0x0: 上升沿和下降沿触发<br>0x1: 下降沿触发<br>0x2: 上升沿触发<br>0x3: 上升沿和下降沿触发 | RW  | 0x0   |
| 1:0    | P04TRG | P04 中断触发源配置位<br>0x0: 上升沿和下降沿触发<br>0x1: 下降沿触发<br>0x2: 上升沿触发<br>0x3: 上升沿和下降沿触发 | RW  | 0x0   |

### 9.3.10. P0\_PND

Addr = 0x58 (XSFR)

| Bit(s) | Name   | Description                          | R/W | Reset |
|--------|--------|--------------------------------------|-----|-------|
| 7      | P07PND | P07 中断标志位<br>0x0: 无触发中断<br>0x1: 触发中断 | RW  | 0x0   |
| 6      | P06PND | P06 中断标志位<br>0x0: 无触发中断<br>0x1: 触发中断 | RW  | 0x0   |
| 5      | P05PND | P05 中断标志位<br>0x0: 无触发中断<br>0x1: 触发中断 | RW  | 0x0   |
| 4      | P04PND | P04 中断标志位<br>0x0: 无触发中断<br>0x1: 触发中断 | RW  | 0x0   |
| 3      | P03PND | P03 中断标志位<br>0x0: 无触发中断<br>0x1: 触发中断 | RW  | 0x0   |
| 2      | P02PND | P02 中断标志位<br>0x0: 无触发中断<br>0x1: 触发中断 | RW  | 0x0   |
| 1      | P01PND | P01 中断标志位<br>0x0: 无触发中断<br>0x1: 触发中断 | RW  | 0x0   |
| 0      | P00PND | P00 中断标志位<br>0x0: 无触发中断<br>0x1: 触发中断 | RW  | 0x0   |

Note: CPU write P0\_PND operation, and clear all pending!!!

### 9.3.11. P0\_IMK

Addr = 0x59 (XSFR)

| Bit(s) | Name   | Description                         | R/W | Reset |
|--------|--------|-------------------------------------|-----|-------|
| 7      | P07IMK | P07 中断屏蔽位<br>0x0: 关闭中断<br>0x1: 打开中断 | RW  | 0x0   |
| 6      | P06IMK | P06 中断屏蔽位<br>0x0: 关闭中断<br>0x1: 打开中断 | RW  | 0x0   |
| 5      | P05IMK | P05 中断屏蔽位<br>0x0: 关闭中断<br>0x1: 打开中断 | RW  | 0x0   |
| 4      | P04IMK | P04 中断屏蔽位<br>0x0: 关闭中断<br>0x1: 打开中断 | RW  | 0x0   |
| 3      | P03IMK | P03 中断屏蔽位<br>0x0: 关闭中断<br>0x1: 打开中断 | RW  | 0x0   |
| 2      | P02IMK | P02 中断屏蔽位<br>0x0: 关闭中断<br>0x1: 打开中断 | RW  | 0x0   |
| 1      | P01IMK | P01 中断屏蔽位<br>0x0: 关闭中断<br>0x1: 打开中断 | RW  | 0x0   |
| 0      | P00IMK | P00 中断屏蔽位<br>0x0: 关闭中断<br>0x1: 打开中断 | RW  | 0x0   |

### 9.3.12. P0\_AIOEN

Addr = 0x5A (XSFR)

| Bit(s) | Name | Description | R/W | Reset |
|--------|------|-------------|-----|-------|
|--------|------|-------------|-----|-------|

|   |          |                                 |    |     |
|---|----------|---------------------------------|----|-----|
| 7 | P07AIOEN | P07 模拟使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 6 | P06AIOEN | P06 模拟使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 5 | P05AIOEN | P05 模拟使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 4 | P04AIOEN | P04 模拟使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 3 | P03AIOEN | P03 模拟使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 2 | P02AIOEN | P02 模拟使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 1 | P01AIOEN | P01 模拟使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 0 | P00AIOEN | P00 模拟使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |

### 9.3.13. P0\_DRV

Addr = 0x5B (XSFR)

| Bit(s) | Name   | Description                            | R/W | Reset |
|--------|--------|----------------------------------------|-----|-------|
| 7      | P07DRV | P07 电流驱动能力配置<br>0x0: 10mA<br>0x1: 50mA | RW  | 0x0   |
| 6      | P06DRV | P06 电流驱动能力配置                           | RW  | 0x0   |

|   |        |                                               |    |     |
|---|--------|-----------------------------------------------|----|-----|
|   |        | 0x0: 10mA<br>0x1: 50mA                        |    |     |
| 5 | P05DRV | <b>P05 电流驱动能力配置</b><br>0x0: 10mA<br>0x1: 50mA | RW | 0x0 |
| 4 | P04DRV | <b>P04 电流驱动能力配置</b><br>0x0: 10mA<br>0x1: 50mA | RW | 0x0 |
| 3 | P03DRV | <b>P03 电流驱动能力配置</b><br>0x0: 10mA<br>0x1: 50mA | RW | 0x0 |
| 2 | P02DRV | <b>P02 电流驱动能力配置</b><br>0x0: 10mA<br>0x1: 50mA | RW | 0x0 |
| 1 | P01DRV | <b>P01 电流驱动能力配置</b><br>0x0: 10mA<br>0x1: 50mA | RW | 0x0 |
| 0 | P00DRV | <b>P00 电流驱动能力配置</b><br>0x0: 10mA<br>0x1: 50mA | RW | 0x0 |

### 9.3.14. P0\_OD

Addr = 0x5C (XSFR)

| Bit(s) | Name  | Description                              | R/W | Reset |
|--------|-------|------------------------------------------|-----|-------|
| 7      | P07OD | P07 open-drain 使能位<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 6      | P06OD | P06 open-drain 使能位<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 5      | P05OD | P05 open-drain 使能位<br>0x0: 关闭            | RW  | 0x0   |

|   |       |                                          |    |     |
|---|-------|------------------------------------------|----|-----|
|   |       | 0x1: 打开                                  |    |     |
| 4 | P04OD | P04 open-drain 使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 3 | P03OD | P03 open-drain 使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 2 | P02OD | P02 open-drain 使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 1 | P01OD | P01 open-drain 使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 0 | P00OD | P00 open-drain 使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |

### 9.3.15. P1

Addr = 0x90 (SFR)

| Bit(s) | Name | Description | R/W | Reset |
|--------|------|-------------|-----|-------|
| 7:0    | P1   | P0 数据寄存器    | RW  | 0x0   |

### 9.3.16. P1\_PU

Addr = 0x60 (XSFR)

| Bit(s) | Name  | Description                              | R/W | Reset |
|--------|-------|------------------------------------------|-----|-------|
| 7:6    | -     | -                                        | -   | -     |
| 5      | P15PU | P15 上拉电阻 (30K) 使能位<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 4      | P14PU | P14 上拉电阻 (30K) 使能位                       | RW  | 0x0   |

|   |       |                                          |    |     |
|---|-------|------------------------------------------|----|-----|
|   |       | 0x0: 关闭<br>0x1: 打开                       |    |     |
| 3 | P13PU | P13 上拉电阻 (30K) 使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 2 | P12PU | P12 上拉电阻 (30K) 使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 1 | P11PU | P11 上拉电阻 (30K) 使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 0 | P10PU | P10 上拉电阻 (30K) 使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |

### 9.3.17. P1\_PD

Addr = 0x61 (XSFR)

| Bit(s) | Name  | Description                              | R/W | Reset |
|--------|-------|------------------------------------------|-----|-------|
| 7:6    | -     | -                                        | -   | -     |
| 5      | P15PD | P15 下拉电阻 (30K) 使能位<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 4      | P14PD | P14 下拉电阻 (30K) 使能位<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 3      | P13PD | P13 下拉电阻 (30K) 使能位<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 2      | P12PD | P12 下拉电阻 (30K) 使能位<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 1      | P11PD | P11 下拉电阻 (30K) 使能位                       | RW  | 0x0   |

|   |       |                                          |    |     |
|---|-------|------------------------------------------|----|-----|
|   |       | 0x0: 关闭<br>0x1: 打开                       |    |     |
| 0 | P10PD | P10 下拉电阻 (30K) 使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |

### 9.3.18. P1\_MD0

Addr = 0x62 (XSFR)

| Bit(s) | Name   | Description                                                                                                                                              | R/W | Reset |
|--------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7:6    | P13MD  | P13 模式配置位<br>0x0: 输入模式<br>0x1: 输出模式<br>0x2: 多功能 IO 模式<br>0x3: 模拟 IO 模式                                                                                   | RW  | 0x0   |
| 5:4    | P12MD  | P12 模式配置位<br>0x0: 输入模式<br>0x1: 输出模式<br>0x2: 多功能 IO 模式<br>0x3: 模拟 IO 模式                                                                                   | RW  | 0x0   |
| 3:2    | P11_MD | P11 模式配置位<br>0x0: 输入模式<br>0x1: 输出模式<br>0x2: 多功能 IO 模式<br>0x3: 模拟 IO 模式                                                                                   | RW  | 0x0   |
| 1:0    | P10_MD | P10 模式配置位<br>0x0: 输入模式<br>0x1: 输出模式<br>0x2: 多功能 IO 模式<br>0x3: 模拟 IO 模式<br><br><b>Note:</b> 如果烧录口为 P10，则需要对应将 IO_MAP[0:1]，即 ISPMAP 设置为 0x03，才能切换为 GPIO 功能 | RW  | 0x0   |

### 9.3.19. P1\_MD1

Addr = 0x63 (XSFR)

| Bit(s) | Name  | Description                                                            | R/W | Reset |
|--------|-------|------------------------------------------------------------------------|-----|-------|
| 7:4    | -     | -                                                                      | -   | -     |
| 3:2    | P15MD | P15 模式配置位<br>0x0: 输入模式<br>0x1: 输出模式<br>0x2: 多功能 IO 模式<br>0x3: 模拟 IO 模式 | RW  | 0x0   |
| 1:0    | P14MD | P14 模式配置位<br>0x0: 输入模式<br>0x1: 输出模式<br>0x2: 多功能 IO 模式<br>0x3: 模拟 IO 模式 | RW  | 0x0   |

### 9.3.20. P1\_AF0

Addr = 0x64 (XSFR)

| Bit(s) | Name  | Description                                                                                                                 | R/W | Reset |
|--------|-------|-----------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7:6    | P13AF | P13 多功能模式下, 功能配置位<br>0x0: STMR2_CHA function<br>0x1: STMR1_CHA function<br>0x2: TMR2_PWM function<br>0x3: UART0_TX function | RW  | 0x0   |
| 5:4    | P12AF | P12 多功能模式下, 功能配置位<br>0x0: STMR2_CHB function<br>0x1: STMR1_CHB function<br>0x2: TMR1_PWM<br>0x3: UART0_RX function          | RW  | 0x0   |

|     |       |                                                                                                                     |    |     |
|-----|-------|---------------------------------------------------------------------------------------------------------------------|----|-----|
| 3:2 | P11AF | P11 多功能模式下, 功能配置位<br>0x0: CMP1_DIG_OUT function<br>0x1: TMR2_CAP function<br>0x2: 保留<br>0x3: PORT_WKUP_IN3 function | RW | 0x0 |
| 1:0 | P10AF | P10 多功能模式下, 功能配置位<br>0x0: STMR2_CHA function<br>0x1: I2C0_SCK function<br>0x2: TMR2_PWM<br>0x3: UART0_TX function   | RW | 0x0 |

### 9.3.21. P1\_AF1

Addr = 0x65 (XSFR)

| Bit(s) | Name  | Description                                                                                                         | R/W | Reset |
|--------|-------|---------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7:4    | -     | -                                                                                                                   | -   | -     |
| 3:2    | P15AF | P15 多功能模式下, 功能配置位<br>0x0: CMPO_DIG_OUT function<br>0x1: TMR1_CAP function<br>0x2: 保留<br>0x3: PORT_WKUP_IN1 function | RW  | 0x0   |
| 1:0    | P14AF | P14 多功能模式下, 功能配置位<br>0x0: CMP1_DIG_OUT function<br>0x1: TMRO_CAP function<br>0x2: 保留<br>0x3: PORT_WKUP_IN0 function | RW  | 0x0   |

### 9.3.22. P1\_TRG0

Addr = 0x66 (XSFR)

| Bit(s) | Name   | Description  | R/W | Reset |
|--------|--------|--------------|-----|-------|
| 7:6    | P13TRG | P13 中断触发源配置位 | RW  | 0x0   |

|     |        |                                                                              |    |     |
|-----|--------|------------------------------------------------------------------------------|----|-----|
|     |        | 0x0: 上升沿和下降沿触发<br>0x1: 下降沿触发<br>0x2: 上升沿触发<br>0x3: 上升沿和下降沿触发                 |    |     |
| 5:4 | P12TRG | P12 中断触发源配置位<br>0x0: 上升沿和下降沿触发<br>0x1: 下降沿触发<br>0x2: 上升沿触发<br>0x3: 上升沿和下降沿触发 | RW | 0x0 |
| 3:2 | P11TRG | P11 中断触发源配置位<br>0x0: 上升沿和下降沿触发<br>0x1: 下降沿触发<br>0x2: 上升沿触发<br>0x3: 上升沿和下降沿触发 | RW | 0x0 |
| 1:0 | P10TRG | P10 中断触发源配置位<br>0x0: 上升沿和下降沿触发<br>0x1: 下降沿触发<br>0x2: 上升沿触发<br>0x3: 上升沿和下降沿触发 | RW | 0x0 |

### 9.3.23. P1\_TRG1

Addr = 0x67 (XSFR)

| Bit(s) | Name   | Description                                                                  | R/W | Reset |
|--------|--------|------------------------------------------------------------------------------|-----|-------|
| 7:4    | -      | -                                                                            | -   | -     |
| 3:2    | P15TRG | P15 中断触发源配置位<br>0x0: 上升沿和下降沿触发<br>0x1: 下降沿触发<br>0x2: 上升沿触发<br>0x3: 上升沿和下降沿触发 | RW  | 0x0   |
| 1:0    | P14TRG | P14 中断触发源配置位<br>0x0: 上升沿和下降沿触发                                               | RW  | 0x0   |

|  |  |                                            |  |  |
|--|--|--------------------------------------------|--|--|
|  |  | 0x1: 下降沿触发<br>0x2: 上升沿触发<br>0x3: 上升沿和下降沿触发 |  |  |
|--|--|--------------------------------------------|--|--|

### 9.3.24. P1\_PND

Addr = 0x68 (XSFR)

| Bit(s) | Name   | Description                          | R/W | Reset |
|--------|--------|--------------------------------------|-----|-------|
| 7:6    | -      | -                                    | -   | -     |
| 5      | P15PND | P15 中断标志位<br>0x0: 无触发中断<br>0x1: 触发中断 | RW  | 0x0   |
| 4      | P14PND | P14 中断标志位<br>0x0: 无触发中断<br>0x1: 触发中断 | RW  | 0x0   |
| 3      | P13PND | P13 中断标志位<br>0x0: 无触发中断<br>0x1: 触发中断 | RW  | 0x0   |
| 2      | P12PND | P12 中断标志位<br>0x0: 无触发中断<br>0x1: 触发中断 | RW  | 0x0   |
| 1      | P11PND | P11 中断标志位<br>0x0: 无触发中断<br>0x1: 触发中断 | RW  | 0x0   |
| 0      | P10PND | P10 中断标志位<br>0x0: 无触发中断<br>0x1: 触发中断 | RW  | 0x0   |

**Note:** CPU write P1\_PND operation, and clear all pending!!!

### 9.3.25. P1\_IMK

Addr = 0x69 (XSFR)

| Bit(s) | Name   | Description                         | R/W | Reset |
|--------|--------|-------------------------------------|-----|-------|
| 7:6    | -      | -                                   | -   | -     |
| 5      | P15IMK | P15 中断屏蔽位<br>0x0: 关闭中断<br>0x1: 打开中断 | RW  | 0x0   |
| 4      | P14IMK | P14 中断屏蔽位<br>0x0: 关闭中断<br>0x1: 打开中断 | RW  | 0x0   |
| 3      | P13IMK | P13 中断屏蔽位<br>0x0: 关闭中断<br>0x1: 打开中断 | RW  | 0x0   |
| 2      | P12IMK | P12 中断屏蔽位<br>0x0: 关闭中断<br>0x1: 打开中断 | RW  | 0x0   |
| 1      | P11IMK | P11 中断屏蔽位<br>0x0: 关闭中断<br>0x1: 打开中断 | RW  | 0x0   |
| 0      | P10IMK | P10 中断屏蔽位<br>0x0: 关闭中断<br>0x1: 打开中断 | RW  | 0x0   |

### 9.3.26. P1\_AIOEN

Addr = 0x6A (XSFR)

| Bit(s) | Name     | Description                     | R/W | Reset |
|--------|----------|---------------------------------|-----|-------|
| 7:6    | -        | -                               | -   | -     |
| 5      | P15AIOEN | P15 模拟使能位<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |

|   |          |                                 |    |     |
|---|----------|---------------------------------|----|-----|
| 4 | P14AIOEN | P14 模拟使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 3 | P13AIOEN | P13 模拟使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 2 | P12AIOEN | P12 模拟使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 1 | P11AIOEN | P11 模拟使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 0 | P10AIOEN | P10 模拟使能位<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |

### 9.3.27. P1\_DRV

Addr = 0x6B (XSFR)

| Bit(s) | Name   | Description                            | R/W | Reset |
|--------|--------|----------------------------------------|-----|-------|
| 7:6    | -      | -                                      | -   | -     |
| 5      | P15DRV | P15 电流驱动能力配置<br>0x0: 10mA<br>0x1: 50mA | RW  | 0x0   |
| 4      | P14DRV | P14 电流驱动能力配置<br>0x0: 10mA<br>0x1: 50mA | RW  | 0x0   |
| 3      | P13DRV | P13 电流驱动能力配置<br>0x0: 10mA<br>0x1: 50mA | RW  | 0x0   |
| 2      | P12DRV | P12 电流驱动能力配置<br>0x0: 10mA<br>0x1: 50mA | RW  | 0x0   |

|   |        |                                        |    |     |
|---|--------|----------------------------------------|----|-----|
| 1 | P11DRV | P11 电流驱动能力配置<br>0x0: 10mA<br>0x1: 50mA | RW | 0x0 |
| 0 | P10DRV | P10 电流驱动能力配置<br>0x0: 10mA<br>0x1: 50mA | RW | 0x0 |

### 9.3.28. P1\_OD

Addr = 0x6C (XSFR)

| Bit(s) | Name  | Description                              | R/W | Reset |
|--------|-------|------------------------------------------|-----|-------|
| 7:6    | -     | -                                        | -   | -     |
| 5      | P15OD | P15 open-drain 使能位<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 4      | P14OD | P14 open-drain 使能位<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 3      | P13OD | P13 open-drain 使能位<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 2      | P12OD | P12 open-drain 使能位<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 1      | P11OD | P11 open-drain 使能位<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 0      | P10OD | P10 open-drain 使能位<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |

## 10. SPI 模块

### 10.1. 功能概述

SPI模块的功能特点如下：

- 支持两线模式
- 支持主从半双工收发
- 极性相位可编程的串行时钟
- 带MCU中断的传输结束标志
- 主模式支持高达 8Mbps 的通讯速率 ( $F_{osc}=32MHz$ )

### 10.2. 模块框图



图 10.2.1 SPI 模块框图

## 10.3. 寄存器列表

表 10-1 SPI 寄存器列表

| Address    | Register Name | Description             |
|------------|---------------|-------------------------|
| 0xF1 (SFR) | SPI0_CON      | SPI0 control register   |
| 0xF2 (SFR) | SPI0_BAUD     | SPI0 baud rate register |
| 0xF3 (SFR) | SPI0_DATA     | SPI0 data register      |
| 0xF4 (SFR) | SPI0_STA      | SPI0 status register    |

## 10.4. 寄存器详细说明

### 10.4.1. SPI0\_CON

Addr = 0xF1 (SFR)

| Bit(s) | Name      | Description                                                              | R/W | Reset |
|--------|-----------|--------------------------------------------------------------------------|-----|-------|
| 7      | -         | -                                                                        | -   | -     |
| 6      | SPISM     | 主从机控制位<br>0x0: 主机<br>0x1: 从机                                             | RW  | 0x0   |
| 5      | SPIRXTX   | 发送接收控制位<br>0x0: 发送数据<br>0x1: 接收数据                                        | RW  | 0x0   |
| 4      | -         | -                                                                        | -   | -     |
| 3      | SPIINTEN  | SPI 中断使能位<br>0x0: 关闭<br>0x1: 打开                                          | RW  | 0x0   |
| 2      | SPISMPSEL | 采样模式选择位<br>1 代表下降沿发送数据上升沿采样, 0 代表上升沿<br>发送数据下降沿采样<br>0x0: 上升沿发送数据, 下降沿采样 | RW  | 0x0   |

|   |         |                                                  |    |     |
|---|---------|--------------------------------------------------|----|-----|
|   |         | 0x1: 下降沿发送数据, 上升沿采样                              |    |     |
| 1 | SPIIDST | 时钟线空闲状态选择位<br>0x0: CLK 空闲为低电平<br>0x1: CLK 空闲为高电平 | RW | 0x0 |
| 0 | SPIEN   | SPI 使能位<br>0x0: 关闭<br>0x1: 打开                    | RW | 0x0 |

#### 10.4.2. SPI0\_BAUD

Addr = 0xF2 (SFR)

| Bit(s) | Name | Description                              | R/W | Reset |
|--------|------|------------------------------------------|-----|-------|
| 7:0    | BAUD | 波特率控制寄存器<br>计算公式: 波特率 = clk/(2*(BAUD+1)) | WO  | 0x0   |

#### 10.4.3. SPI0\_DATA

Addr = 0xF3 (SFR)

| Bit(s) | Name | Description                               | R/W | Reset |
|--------|------|-------------------------------------------|-----|-------|
| 7:0    | DATA | 数据寄存器<br>使能后将数据写入DATA触发发送, 读DATA则读出接收到的数据 | RW  | -     |

#### 10.4.4. SPI0\_STA

Addr = 0xF4 (SFR)

| Bit(s) | Name   | Description | R/W | Reset |
|--------|--------|-------------|-----|-------|
| 7:2    | -      | -           | -   | -     |
| 1      | SPIINT | SPI 中断标志    | RO  | 0x0   |

|   |         |                                        |    |     |
|---|---------|----------------------------------------|----|-----|
|   |         | 写 1 清零                                 |    |     |
| 0 | SPIPEND | SPI 状态标志位<br>0x0: 正在发送或正在接收<br>0x1: 空闲 | RO | 0x1 |

## 10.5. 使用流程说明

1. 主机 TX: 配置 SPI\_ENABLE 使能位, SPI\_RX\_TX 配 0 表示发送, 将要发送的数据写入 DATA 触发发送。
2. 主机 RX: 配置 SPI\_ENABLE 使能位, SPI\_RX\_TX 配 1 表示接收。写入任意数据到 DATA 触发接收, 接收完成 (SPI\_PENDING=1) 读 DATA 读出数据。
3. 从机 TX: 配置 SPI\_ENABLE 使能位, SPI\_SM 配 1 表示从机模式, SPI\_RX\_TX 配 0 表示发送。将要发送的数据写入 DATA 触发 SPI 等待主机时钟。
4. 从机 RX: 配置 SPI\_ENABLE 使能位, SPI\_SM 配 1 表示从机模式, SPI\_RX\_TX 配 1 表示发送。写入任意数据到 DATA 触发 SPI 等待主机时钟。

## 11.UART0/1 模块

### 11.1. 功能概述

UART 模块功能特点:

- 支持半双工
- 支持发送 9bit 数据
- 支持软件奇偶校验

## 11.2. 模块框图



图 11.2.1 UART 模块框图

## 11.3. 寄存器列表

表 11-1 UART 寄存器列表

| Address    | Register Name | Description                                         |
|------------|---------------|-----------------------------------------------------|
| 0xF6 (SFR) | UART0_CON     | UART0 control register                              |
| 0xF7 (SFR) | UART0_STA     | UART0 status register                               |
| 0xF8 (SFR) | UART0_BAUD0   | The low eight bits of the UART0 baud rate register  |
| 0xF9 (SFR) | UART0_BAUD1   | The high eight bits of the UART0 baud rate register |
| 0xFA (SFR) | UART0_DATA    | UART0 data register                                 |
| 0xFB (SFR) | UART1_CON     | UART1 control register                              |
| 0xFC (SFR) | UART1_STA     | UART1 status register                               |

|            |             |                                                     |
|------------|-------------|-----------------------------------------------------|
| 0xFD (SFR) | UART1_BAUD0 | The low eight bits of the UART1 baud rate register  |
| 0xFE (SFR) | UART1_BAUD1 | The high eight bits of the UART1 baud rate register |
| 0xFF (SFR) | UART1_DATA  | UART1 data register                                 |

## 11.4. 寄存器详细说明

### 11.4.1. UART0\_CON

Addr = 0xF6 (SFR)

| Bit(s) | Name     | Description                                             | R/W | Reset |
|--------|----------|---------------------------------------------------------|-----|-------|
| 7      | STOPBIT  | 停止位控制位<br>0x0: 不发送停止位<br>0x1: 发送 1bit 停止位               | RW  | 0x0   |
| 6      | NINTHBIT | 将需要发送的第 9bit 数据写入该寄存器                                   | RW  | 0x0   |
| 5      | BIT9EN   | 发送 9bit 数据使能位<br>0x0: 一次发送 8bit 数据<br>0x1: 一次发送 9bit 数据 | RW  | 0x0   |
| 4      | UARTEN   | UART 使能位<br>0x0: 关闭<br>0x1: 打开                          | RW  | 0x0   |
| 3      | TXINV    | TX 电平取反控制位<br>0x0: 不取反<br>0x1: 取反                       | RW  | 0x0   |
| 2      | RXINV    | RX 电平取反控制位<br>0x0: 不取反<br>0x1: 取反                       | RW  | 0x0   |
| 1      | TXRXSEL  | TX/RX 选择位<br>0x0: TX 模式<br>0x1: RX 模式                   | RW  | 0x0   |
| 0      | UARTIE   | RX 中断使能位                                                | RW  | 0x0   |

|  |  |                    |  |  |
|--|--|--------------------|--|--|
|  |  | 0x0: 关闭<br>0x1: 打开 |  |  |
|--|--|--------------------|--|--|

#### 11.4.2. UART0\_STA

Addr = 0xF7 (SFR)

| Bit(s) | Name    | Description                                                             | R/W | Reset |
|--------|---------|-------------------------------------------------------------------------|-----|-------|
| 7      | RXBIT9  | 接收的第 9bit, 读该位读出第 9bit 数据                                               | RO  | 0x0   |
| 6      | FERR    | 接收到的奇偶校验位数据<br>奇偶校验由软件进行(接收 8bit 数据加奇偶校验位时不使能 BIT9_EN 的情况下, 在此位读出奇偶校验位) | RO  | 0x0   |
| 5      | RXDONE  | RX 状态标志位<br>该位为 1 表示 buff 接收满数据, 写 1 清零或读取之后才会开始下一帧数据的接收                | RO  | 0x0   |
| 4      | TXDONE  | TX 状态标志位<br>0x0: 正在发送数据<br>0x1: 空闲                                      | RO  | 0x0   |
| 3      | UARTINT | 中断标志位<br>高电平表示请求中断, 写 1 清除中断                                            | RO  | 0x0   |
| 2:0    | -       | -                                                                       | -   | -     |

#### 11.4.3. UART0\_BAUD0

Addr = 0xF8 (SFR)

| Bit(s) | Name      | Description                                           | R/W | Reset |
|--------|-----------|-------------------------------------------------------|-----|-------|
| 7:0    | UARTBAUDL | 波特率寄存器低 8Bytes<br>UART 波特率寄存器, 计算公式: sysclk/ (baud+1) | WO  | 0x0   |

#### 11.4.4. UART0\_BAUD1

Addr = 0xF9 (SFR)

| Bit(s) | Name      | Description                                            | R/W | Reset |
|--------|-----------|--------------------------------------------------------|-----|-------|
| 7:0    | UARTBAUDH | 波特率寄存器高 8Bytes<br>UART 波特率寄存器, 计算公式: sysclk / (baud+1) | WO  | 0x0   |

#### 11.4.5. UART0\_DATA

Addr = 0xFA (SFR)

| Bit(s) | Name | Description                                   | R/W | Reset |
|--------|------|-----------------------------------------------|-----|-------|
| 7:0    | DATA | 数据寄存器<br>使能之后向该寄存器写入数据则触发该数据的发送, 读该寄存器取得接收的数据 | RW  | 0x0   |

#### 11.4.6. UART1\_CON

Addr = 0xFB (SFR)

| Bit(s) | Name     | Description                                             | R/W | Reset |
|--------|----------|---------------------------------------------------------|-----|-------|
| 7      | STOPBIT  | 停止位控制位<br>0x0: 不发送停止位<br>0x1: 发送 1bit 停止位               | RW  | 0x0   |
| 6      | NINTHBIT | 将需要发送的第 9bit 数据写入该寄存器                                   | RW  | 0x0   |
| 5      | BIT9EN   | 发送 9bit 数据使能位<br>0x0: 一次发送 8bit 数据<br>0x1: 一次发送 9bit 数据 | RW  | 0x0   |
| 4      | UARTEN   | UART 使能位<br>0x0: 关闭<br>0x1: 打开                          | RW  | 0x0   |
| 3      | TXINV    | TX 电平取反控制位<br>0x0: 不取反                                  | RW  | 0x0   |

|   |         |                                   |    |     |
|---|---------|-----------------------------------|----|-----|
|   |         | 0x1: 取反                           |    |     |
| 2 | RXINV   | RX 电平取反控制位<br>0x0: 不取反<br>0x1: 取反 | RW | 0x0 |
| 1 | TXRXSEL | TX/RX 选择位<br>0x0: 关闭<br>0x1: 打开   | RW | 0x0 |
| 0 | UARTIE  | RX 中断使能位<br>0x0: 关闭<br>0x1: 打开    | RW | 0x0 |

#### 11.4.7. UART1\_STA

Addr = 0xFC (SFR)

| Bit(s) | Name    | Description                                                             | R/W | Reset |
|--------|---------|-------------------------------------------------------------------------|-----|-------|
| 7      | RXBIT9  | 接收的第 9bit, 读该位读出第 9bit 数据                                               | RO  | 0x0   |
| 6      | FERR    | 接收到的奇偶校验位数据<br>奇偶校验由软件进行(接收 8bit 数据加奇偶校验位时不使能 BIT9_EN 的情况下, 在此位读出奇偶校验位) | RO  | 0x0   |
| 5      | RXDONE  | RX 状态标志位<br>该位为 1 表示 buff 接收满数据, 写 1 清零或读取之后才会开始下一帧数据的接收                | RO  | 0x0   |
| 4      | TXDONE  | TX 状态标志位<br>0x0: 正在发送数据<br>0x1: 空闲                                      | RO  | 0x0   |
| 3      | UARTINT | 中断标志位<br>高电平表示请求中断, 写 1 清除中断                                            | RO  | 0x0   |
| 2:0    | -       | -                                                                       | -   | -     |

#### 11.4.8. UART1\_BAUD0

Addr = 0xFD (SFR)

| Bit(s) | Name      | Description                                          | R/W | Reset |
|--------|-----------|------------------------------------------------------|-----|-------|
| 7:0    | UARTBAUDL | 波特率寄存器低 8Bytes<br>UART 波特率寄存器, 计算公式: sysclk/(baud+1) | WO  | 0x0   |

#### 11.4.9. UART1\_BAUD1

Addr = 0xFE (SFR)

| Bit(s) | Name      | Description                                          | R/W | Reset |
|--------|-----------|------------------------------------------------------|-----|-------|
| 7:0    | UARTBAUDH | 波特率寄存器高 8Bytes<br>UART 波特率寄存器, 计算公式: sysclk/(baud+1) | WO  | 0x0   |

#### 11.4.10. UART1\_DATA

Addr = 0xFF (SFR)

| Bit(s) | Name | Description                                   | R/W | Reset |
|--------|------|-----------------------------------------------|-----|-------|
| 7:0    | DATA | 数据寄存器<br>使能之后向该寄存器写入数据则触发该数据的发送, 读该寄存器取得接收的数据 | RW  | 0x0   |

### 11.5. 使用流程说明

发送数据:

使能模块 (UART0->CON |= BIT(4)) , 将需要发送的数据写入 DATA 即开始发送 (UART0->DATA=x) , 如需发送 9bit 数据则使能 BIT9\_EN 并先将第 9bit 数据写入 NINTH\_BIT 再将前 8 位数据写入 DATA 开始发送。

### **接收数据：**

只需使能模块即开始检测起始位，当接收满一帧数据 RX\_DONE 会置 1 表示 buff 收满，此时可将接收的数据读走，必需将 RX\_DONE 写 1 清零才会接收下一帧数据 (UART0->STA=BIT(5))。

## **12. 基本 Timer 0/1 模块**

### **12.1. 功能概述**

基本 Timer0/1 是两个 8bit 的基础功能定时器，支持多种计数时钟源选择，支持定时器模式，计数器模式，捕获模式，和 PWM 模式等多种工作模式。支持 Timer0 和 Timer1 级联组成 16bit 的定时器工作模式。

## 12.2. 模块框图



图 13-1 Timer0/1 模块框图

## 12.3. 寄存器列表

表 13-1 Timer0/1 寄存器列表

| Address    | Register Name | Description                       |
|------------|---------------|-----------------------------------|
| 0x88 (SFR) | TMRO_CONL     | TIMER0 control low 8bit register  |
| 0x89 (SFR) | TMRO_CONH     | TIMER0 control high 8bit register |
| 0x8A (SFR) | TMRO_CNTL     | TIMER0 counter low 8bit register  |
| 0x8C (SFR) | TMRO_PRL      | TIMER0 period low 8bit register   |
| 0x8E (SFR) | TMRO_PWML     | TIMER0 PWM low 8bit register      |
| 0xB0 (SFR) | TMR1_CONL     | TIMER1 control low 8bit register  |

|            |           |                                   |
|------------|-----------|-----------------------------------|
| 0xB1 (SFR) | TMR1_CONH | TIMER1 control high 8bit register |
| 0xB2 (SFR) | TMR1_CNTL | TIMER1 counter low 8bit register  |
| 0xB4 (SFR) | TMR1_PRL  | TIMER1 period low 8bit register   |
| 0xB6 (SFR) | TMR1_PWML | TIMER1 PWM low 8bit register      |

## 12.4. 寄存器详细说明

### 12.4.1. TMR0\_CONL

Addr = 0x88 (SFR)

| Bit(s) | Name   | Description                                                                                                                                                                                                                                               | R/W | Reset |
|--------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7:5    | PSC    | <b>TIMER0 预分频配置</b><br>0x0: 不分频<br>0x1: 2 分频<br>0x2: 4 分频<br>0x3: 8 分频<br>0x4: 16 分频<br>0x5: 32 分频<br>0x6: 64 分频<br>0x7: 128 分频                                                                                                                           | RW  | 0x0   |
| 4:2    | INCSRC | <b>TIMER0 计数源选择配置</b><br>0x0: T0 rising edge<br>0x1: T0 falling edge<br>0x2: hirc_clk_div2 edge(rising & falling)<br>0x3: rc64k_div2 edge(rising & falling)<br>0x4: xoscm_div2 edge(rising & falling)<br>0x5: Timer1 over<br>0x6: sys_clk<br>0x7: sys_clk | RW  | 0x0   |
| 1:0    | MODE   | <b>TIMER0 工作模式配置</b><br>0x0: 关闭                                                                                                                                                                                                                           | RW  | 0x0   |

|  |  |                                                         |  |  |
|--|--|---------------------------------------------------------|--|--|
|  |  | 0x1: COUNTER MODE<br>0x2: PWM MODE<br>0x3: CAPTURE MODE |  |  |
|--|--|---------------------------------------------------------|--|--|

### 12.4.2. TMR0\_CONH

Addr = 0x89 (SFR)

| Bit(s) | Name   | Description                                                                                            | R/W | Reset |
|--------|--------|--------------------------------------------------------------------------------------------------------|-----|-------|
| 7      | TMRPND | TIMER0 计数 pending 位 (写 1 清 pending)<br>0x0: 没有计数 pending<br>0x1: 有计数 pending                           | RW  | 0x0   |
| 6      | CAPPND | TIMER0 捕获 pending 位 (写 1 清 pending)<br>0x0: 没有捕获 pending<br>0x1: 有捕获 pending                           | RW  | 0x0   |
| 5      | TMRIE  | TIMER0 计数中断使能位<br>0x0: 关闭<br>0x1: 打开                                                                   | RW  | 0x0   |
| 4      | CAPIE  | TIMER0 捕获中断使能位<br>0x0: 关闭<br>0x1: 打开                                                                   | RW  | 0x0   |
| 3:2    | INCSRC | TIMER0 捕获源选择配置<br>0x0: TO 引脚作为捕获源<br>0x1: TO 引脚作为捕获源<br>0x2: 比较器 0 的数字输出作为捕获源<br>0x3: 比较器 1 的数字输出作为捕获源 | RW  | 0x0   |
| 1:0    | CAPEDG | TIMER0 捕获 TO 引脚的边沿触发设置<br>0x0: TO 上升沿触发捕获<br>0x1: TO 下降沿触发捕获<br>0x2: TO 双边沿触发捕获<br>0x3: TO 双边沿触发捕获     | RW  | 0x0   |

### 12.4.3. TMR0\_CNTL

Addr = 0x8A (SFR)

| Bit(s) | Name | Description   | R/W | Reset |
|--------|------|---------------|-----|-------|
| 7:0    | CNT  | TIMER0 计数器初始值 | RW  | 0x0   |

### 12.4.4. TMR0\_PRL

Addr = 0x8C (SFR)

| Bit(s) | Name | Description    | R/W | Reset |
|--------|------|----------------|-----|-------|
| 7:0    | PRD  | TIMER0 计数周期设置值 | RW  | 0xFF  |

### 12.4.5. TMR0\_PWML

Addr = 0x8E (SFR)

| Bit(s) | Name | Description                                                                                       | R/W | Reset |
|--------|------|---------------------------------------------------------------------------------------------------|-----|-------|
| 7:0    | PWM  | <b>TIMER0 占空比设置值</b><br>在 PWM 工作模式是, 该值是设置位 PWM 的占空比设置值; 在捕获工作模式时, 当捕获到捕获源之后抓取的计数器的值锁存在 PWM 寄存器中。 | RW  | 0x0   |

### 12.4.6. TMR1\_CONL

Addr = 0xB0 (SFR)

| Bit(s) | Name | Description                                               | R/W | Reset |
|--------|------|-----------------------------------------------------------|-----|-------|
| 7:5    | PSC  | <b>TIMER1 预分频配置</b><br>0x0: 不分频<br>0x1: 2 分频<br>0x2: 4 分频 | RW  | 0x0   |

|     |        |                                                                                                                                                                                                                                                           |    |     |
|-----|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|
|     |        | 0x3: 8 分频<br>0x4: 16 分频<br>0x5: 32 分频<br>0x6: 64 分频<br>0x7: 128 分频                                                                                                                                                                                        |    |     |
| 4:2 | INCSRC | <b>TIMER1 计数源选择配置</b><br>0x0: T0 rising edge<br>0x1: T0 falling edge<br>0x2: hirc_clk_div2 edge(rising & falling)<br>0x3: rc64k_div2 edge(rising & falling)<br>0x4: xoscm_div2 edge(rising & falling)<br>0x5: Timer0 over<br>0x6: sys_clk<br>0x7: sys_clk | RW | 0x0 |
| 1:0 | MODE   | <b>TIMER1 工作模式配置</b><br>0x0: 关闭<br>0x1: COUNTER MODE<br>0x2: PWM MODE<br>0x3: CAPTURE MODE                                                                                                                                                                | RW | 0x0 |

#### 12.4.7. TMR1\_CONH

Addr = 0xB1 (SFR)

| Bit(s) | Name   | Description                                                                         | R/W | Reset |
|--------|--------|-------------------------------------------------------------------------------------|-----|-------|
| 7      | TMRPND | <b>TIMER1 计数 pending 位 (写 1 清 pending)</b><br>0x0: 没有计数 pending<br>0x1: 有计数 pending | RW  | 0x0   |
| 6      | CAPPND | <b>TIMER1 捕获 pending 位 (写 1 清 pending)</b><br>0x0: 没有捕获 pending<br>0x1: 有捕获 pending | RW  | 0x0   |
| 5      | TMRIE  | <b>TIMER1 计数中断使能位</b><br>0x0: 关闭<br>0x1: 打开                                         | RW  | 0x0   |

|     |        |                                                                                                        |    |     |
|-----|--------|--------------------------------------------------------------------------------------------------------|----|-----|
| 4   | CAPIE  | TIMER1 捕获中断使能位<br>0x0: 关闭<br>0x1: 打开                                                                   | RW | 0x0 |
| 3:2 | INCSRC | TIMER1 捕获源选择配置<br>0x0: T1 引脚作为捕获源<br>0x1: T1 引脚作为捕获源<br>0x2: 比较器 0 的数字输出作为捕获源<br>0x3: 比较器 1 的数字输出作为捕获源 | RW | 0x0 |
| 1:0 | CAPEDG | TIMER1 捕获 T0 引脚的边沿触发设置<br>0x0: T1 上升沿触发捕获<br>0x1: T1 下降沿触发捕获<br>0x2: T1 双边沿触发捕获<br>0x3: T1 双边沿触发捕获     | RW | 0x0 |

#### 12.4.8. TMR1\_CNTL

Addr = 0xB2 (SFR)

| Bit(s) | Name | Description   | R/W | Reset |
|--------|------|---------------|-----|-------|
| 7:0    | CNT  | TIMER1 计数器初始值 | RW  | 0x0   |

#### 12.4.9. TMR1\_PRL

Addr = 0xB4 (SFR)

| Bit(s) | Name | Description    | R/W | Reset |
|--------|------|----------------|-----|-------|
| 7:0    | PRD  | TIMER1 计数周期设置值 | RW  | 0xFF  |

#### 12.4.10. TMR1\_PWML

Addr = 0xB6 (SFR)

| Bit(s) | Name | Description | R/W | Reset |
|--------|------|-------------|-----|-------|
|        |      |             |     |       |

|     |     |                                                                                                |    |     |
|-----|-----|------------------------------------------------------------------------------------------------|----|-----|
| 7:0 | PWM | <b>TIMER1 占空比设置值</b><br>在 PWM 工作模式是，该值是设置位 PWM 的占空比设置值；在捕获工作模式时，当捕获到捕获源之后抓取的计数器的值锁存在 PWM 寄存器中。 | RW | 0x0 |
|-----|-----|------------------------------------------------------------------------------------------------|----|-----|

## 12.5. 使用流程说明

以 Timer0 为例，Timer1 同 Timer0。

### 12.5.1. 计数器/定时器工作模式

- (1) 写 TMRO\_CONH.bit7, TMRO\_CONH.bit6 1 清 pending;
- (2) 配置计数器初始值，写寄存器 TMRO\_CNTL;
- (3) 配置计数周期值，写寄存器 TMRO\_PRL;
- (4) 选择计数器的计数源，写寄存器 TMRO\_CONL[4:2];
- (5) 配置计数源的预分频，写寄存器 TMRO\_CONL[7:5];
- (6) 如果选择使用计数中断，写寄存器 TMRO\_CONH[5]配置 TMR\_IE=1;
- (7) 配置 TMRO\_CONL[1:0]=2' b01, 工作在 Timer mode;
- (8) 等 TMRO\_CONH[7]=1, 即产生了 TIMER PENDING;如果中断使能了，会进入中断，执行对应的中断服务子程序。

### 12.5.2. 捕获工作模式

- (1) 写 TMRO\_CONH.bit7, TMRO\_CONH.bit6 1 清 pending;
- (2) 配置计数器初始值，写寄存器 TMRO\_CNTL;
- (3) 配置计数周期值，写寄存器 TMRO\_PRL;
- (4) 配置 TMRO\_PWML=0;

- (5) 选择计数器的计数源，写寄存器 TMRO\_CONL[4:2]；
- (6) 配置计数源的预分频，写寄存器 TMRO\_CONL[7:5]；
- (7) 配置 TMRO\_CONH[3:2]选择捕获源；
- (8) 如果捕获源选择的是 T0 引脚，需要配置 TMRO\_CONH[1:0]选择捕获边沿；
- (9) 如果选择使用捕获中断，写寄存器 TMRO\_CONH[4]配置 CAP\_IE=1；
- (10) 配置 TMRO\_CONL[1:0]=2' b11, 工作在捕获模式；
- (11) 等 TMRO\_CONH[6]=1, 即产生了 CAP PENDING;如果中断使能了，会进入中断，执行对应的中断服务子程序；
- (12) 读取捕获事件发生时的计数器值，通过读寄存器 TMRO\_PWML。

### 12.5.3. PWM 工作模式

- (1) 写 TMRO\_CONH.bit7, TMRO\_CONH.bit6 1 清 pending；
- (2) 配置计数器初始值，写寄存器 TMRO\_CNTL；
- (3) 配置计数周期值，写寄存器 TMRO\_PRL；
- (4) 配置 PWM 的占空比，写寄存器 TMRO\_PWML；
- (5) 选择计数器的计数源，写寄存器 TMRO\_CONL[4:2]；
- (6) 配置计数源的预分频，写寄存器 TMRO\_CONL[7:5]；
- (7) 配置 TMRO\_CONL[1:0]=2' b10, 工作在 PWM 模式。

## 13. 基本 Timer2 模块

### 13.1. 功能概述

基本 Timer2 是 16bit 的基础功能定时器，支持多种计数时钟源选择，支持定时器模式、

计数器模式、捕获模式和 PWM 模式等多种工作模式。

## 13.2. 模块框图



图 14-1 Timer2 的模块框图

## 13.3. 寄存器列表

表 14-1 Timer2 寄存器列表

| Address    | Register Name | Description                       |
|------------|---------------|-----------------------------------|
| 0xC0 (SFR) | TMR2_CONL     | TIMER2 control low 8bit register  |
| 0xC1 (SFR) | TMR2_CONH     | TIMER2 control high 8bit register |
| 0xC2 (SFR) | TMR2_CNTL     | TIMER2 counter low 8bit register  |
| 0xC3 (SFR) | TMR2_CNTH     | TIMER2 counter high 8bit register |
| 0xC4 (SFR) | TMR2_PRL      | TIMER2 period low 8bit register   |

|            |           |                                  |
|------------|-----------|----------------------------------|
| 0xC5 (SFR) | TMR2_PRH  | TIMER2 period high 8bit register |
| 0xC6 (SFR) | TMR2_PWML | TIMER2 PWM low 8bit register     |
| 0xC7 (SFR) | TMR2_PWMH | TIMER2 PWM high 8bit register    |

## 13.4. 寄存器详细说明

### 13.4.1. TMR2\_CONL

Addr = 0xC0 (SFR)

| Bit(s) | Name   | Description                                                                                                                                                                                                                                           | R/W | Reset |
|--------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7:5    | PSC    | <b>TIMER2 预分频配置</b><br>0x0: 不分频<br>0x1: 2 分频<br>0x2: 4 分频<br>0x3: 8 分频<br>0x4: 16 分频<br>0x5: 32 分频<br>0x6: 64 分频<br>0x7: 128 分频                                                                                                                       | RW  | 0x0   |
| 4:2    | INCSRC | <b>TIMER2 计数源选择配置</b><br>0x0: T2 rising edge<br>0x1: T2 falling edge<br>0x2: hirc_clk_div2 edge(rising & falling)<br>0x3: rc64k_div2 edge(rising & falling)<br>0x4: xoscm_div2 edge(rising & falling)<br>0x5: sys_clk<br>0x6: sys_clk<br>0x7: sys_clk | RW  | 0x0   |
| 1:0    | MODE   | <b>TIMER2 工作模式配置</b><br>0x0: 关闭<br>0x1: COUNTER MODE                                                                                                                                                                                                  | RW  | 0x0   |

|  |  |                                    |  |  |
|--|--|------------------------------------|--|--|
|  |  | 0x2: PWM MODE<br>0x3: CAPTURE MODE |  |  |
|--|--|------------------------------------|--|--|

### 13.4.2. TMR2\_CONH

Addr = 0xC1 (SFR)

| Bit(s) | Name   | Description                                                                                            | RW | Reset |
|--------|--------|--------------------------------------------------------------------------------------------------------|----|-------|
| 7      | TMRPND | TIMER2 计数 pending 位 (写 1 清 pending)<br>0x0: 没有计数 pending<br>0x1: 有计数 pending                           | RW | 0x0   |
| 6      | CAPPND | TIMER2 捕获 pending 位 (写 1 清 pending)<br>0x0: 没有捕获 pending<br>0x1: 有捕获 pending                           | RW | 0x0   |
| 5      | TMRIE  | TIMER2 计数中断使能位<br>0x0: 关闭<br>0x1: 打开                                                                   | RW | 0x0   |
| 4      | CAPIE  | TIMER2 捕获中断使能位<br>0x0: 关闭<br>0x1: 打开                                                                   | RW | 0x0   |
| 3:2    | INCSRC | TIMER2 捕获源选择配置<br>0x0: T2 引脚作为捕获源<br>0x1: T2 引脚作为捕获源<br>0x2: 比较器 0 的数字输出作为捕获源<br>0x3: 比较器 1 的数字输出作为捕获源 | RW | 0x0   |
| 1:0    | CAPEDG | TIMER2 捕获 T2 引脚的边沿触发设置<br>0x0: T2 上升沿触发捕获<br>0x1: T2 下降沿触发捕获<br>0x2: T2 双边沿触发捕获<br>0x3: T2 双边沿触发捕获     | RW | 0x0   |

### 13.4.3. TMR2\_CNTL

Addr = 0xC2 (SFR)

| Bit(s) | Name | Description          | R/W | Reset |
|--------|------|----------------------|-----|-------|
| 7:0    | CNTL | TIMER2 计数器低 8bit 初始值 | RW  | 0x0   |

### 13.4.4. TMR2\_CNTH

Addr = 0xC3 (SFR)

| Bit(s) | Name | Description          | R/W | Reset |
|--------|------|----------------------|-----|-------|
| 7:0    | CNTH | TIMER2 计数器高 8bit 初始值 | RW  | 0x0   |

### 13.4.5. TMR2\_PRL

Addr = 0xC4 (SFR)

| Bit(s) | Name | Description           | R/W | Reset |
|--------|------|-----------------------|-----|-------|
| 7:0    | PRDL | TIMER2 计数周期低 8bit 设置值 | RW  | 0xFF  |

### 13.4.6. TMR2\_PRH

Addr = 0xC5 (SFR)

| Bit(s) | Name | Description           | R/W | Reset |
|--------|------|-----------------------|-----|-------|
| 7:0    | PRDH | TIMER2 计数周期高 8bit 设置值 | RW  | 0xFF  |

### 13.4.7. TMR2\_PWML

Addr = 0xC6 (SFR)

| Bit(s) | Name | Description | R/W | Reset |
|--------|------|-------------|-----|-------|
|        |      |             |     |       |

|     |     |                                                                                                |    |     |
|-----|-----|------------------------------------------------------------------------------------------------|----|-----|
| 7:0 | PWM | TIMER2 占空比低 8bit 设置值<br>在 PWM 工作模式是，该值是设置位 PWM 的占空比设置值；在捕获工作模式时，当捕获到捕获源之后抓取的计数器的值锁存在 PWM 寄存器中。 | RW | 0x0 |
|-----|-----|------------------------------------------------------------------------------------------------|----|-----|

### 13.4.8. TMR2\_PWMH

Addr = 0xC7 (SFR)

| Bit(s) | Name | Description                                                                                    | R/W | Reset |
|--------|------|------------------------------------------------------------------------------------------------|-----|-------|
| 7:0    | PWM  | TIMER2 占空比高 8bit 设置值<br>在 PWM 工作模式是，该值是设置位 PWM 的占空比设置值；在捕获工作模式时，当捕获到捕获源之后抓取的计数器的值锁存在 PWM 寄存器中。 | RW  | 0x0   |

## 13.5. 使用流程说明

### 13.5.1. 计数器/定时器工作模式

- (1) 写 TMR2\_CONH.bit7, TMR2\_CONH.bit6 1 清 pending;
- (2) 配置计数器初始值，写寄存器 TMR2\_CNTL, TMR2\_CNTLH;
- (3) 配置计数周期值，写寄存器 TMR2\_PRL, TMR2\_PRH;
- (4) 选择计数器的计数源，写寄存器 TMR2\_CONL[4:2];
- (5) 配置计数源的预分频，写寄存器 TMR2\_CONL[7:5];
- (6) 如果选择使用计数中断，写寄存器 TMR2\_CONH[5]配置 TMR\_IE=1;
- (7) 配置 TMR2\_CONL[1:0]=2' b01, 工作在 Timer mode;
- (8) 等 TMR2\_CONH[7]=1，即产生了 TIMER PENDING;如果中断使能了，会进入中断，执行对应的中断服务子程序。

### 13.5.2. 捕获工作模式

- (1) 写 TMR2\_CONH.bit7, TMR2\_CONH.bit6 1 清 pending;
- (2) 配置计数器初始值, 写寄存器 TMR2\_CNTL, TMR2\_CNTH;
- (3) 配置计数周期值, 写寄存器 TMR2\_PRL, TMR2\_PRH;
- (4) 配置 TMR2\_PWML=0, TMR2\_PWMH=0;
- (5) 选择计数器的计数源, 写寄存器 TMR2\_CONL[4:2];
- (6) 配置计数源的预分频, 写寄存器 TMR2\_CONL[7:5];
- (7) 配置 TMR2\_CONH[3:2]选择捕获源;
- (8) 如果捕获源选择的是 T2 引脚, 需要配置 TMR2\_CONH[1:0]选择捕获边沿;
- (9) 如果选择使用捕获中断, 写寄存器 TMR2\_CONH[4]配置 CAP\_IE=1;
- (10) 配置 TMR2\_CONL[1:0]=2' b11, 工作在捕获模式;
- (11) 等 TMR2\_CONH[6]=1, 即产生了 CAP PENDING; 如果中断使能了, 会进入中断, 执行对应的中断服务子程序;
- (12) 读取捕获事件发生时的计数器值, 通过读寄存器 TMR2\_PWML, TMR2\_PWMH。

### 13.5.3. PWM 工作模式

- (1) 写 TMR2\_CONH.bit7, TMR2\_CONH.bit6 1 清 pending;
- (2) 配置计数器初始值, 写寄存器 TMR2\_CNTL, TMR2\_CNTH;
- (3) 配置计数周期值, 写寄存器 TMR2\_PRL, TMR2\_PRH;
- (4) 配置 PWM 的占空比, 写寄存器 TMR2\_PWML, TMR2\_PWMH;
- (5) 选择计数器的计数源, 写寄存器 TMR2\_CONL[4:2];
- (6) 配置计数源的预分频, 写寄存器 TMR2\_CONL[7:5];
- (7) 配置 TMR2\_CONL[1:0]=2' b10, 工作在 PWM 模式。

## 14. 高级 Timer 1/2 模块

### 14.1. 功能概述

高级定时器是一个包含两个定时器 STMR1/2。STMR1/2 是功能相同的高级计数器，可用于产生不同形式的时钟波形，一个定时器可以产生同频的一组互补 PWM，或者周期相同、占空比不同的 2 路 PWM。可以捕获外界输入进行脉冲宽度或周期测量。

主要特性如下：

- 内置 16 位计数器，向上或者向下计数，自动重装
- 时钟源可选择来自系统系统时钟或者内部晶振或者外部RTC时钟
- 预分频 1-16
- 后分频 1、2、4、8、16、32、64、128(周期间隔响应)
- 和外部信号同步（外部时钟，复位）
- 输入捕捉（上升沿，下降沿和双沿）和比较功能
- 对输入沿计数，可选上升沿，下降沿和双沿
- 刹车输入，可以将TMR1/2 的输出置位特定的状态
- 支持PWM输出功能
- 可输出周期相同、占空比不同的 2 路 PWM，或者 1 路互补 PWM，互补输出可编程死区
- 支持刹车功能，刹车输入为比较器输出
- 影子寄存器，触发更新事件才能更新
- 中断，在以下事件产生中断：
  - 计数器上溢
  - 计数器下溢
  - CHA/CHB 输入捕捉
  - CHA/CHB 输出比较
  - 刹车产生（软件或比较器）

### 14.1.1. 基本动作

#### 1、基本波形模式

TIMER1/2 有 2 种基本计数波形模式，锯齿波模式和三角波模式。波形模式又由于不同的内部计数动作有所细分，三角波模式分为三角波 A 模式、三角波 B 模式。锯齿波和三角波的基本波形如所示。三角波 A 模式与三角波 B 模式区别在于缓存传送有差别，三角波 A 模式一个周期只发生一次缓存传送（谷点），而三角波 B 模式一个周期发生两次缓存传送（峰点和谷点）。



图 15-1 基础波形图

#### 2、比较输出

STMR1/2 一个定时器有 2 个比较输出端口（CHA、CHB），可在计数值与计数基准值比较匹配时输出指定的电平。CMPA\_S ({CMWAH\_S, CMPAL\_S})、CMPB\_S ({CMPBH\_S, CMPBL\_S}) 寄

存器分别对应了 CHA、CHB 的计数比较基准值。当计数器的计数值和 CMPA\_S 相等时，CHA 端口输出指定的电平；当计数器的计数值和 CMPB\_S 相等时，CHB 端口输出指定电平。

CHA、CHB 端口的计数起始电平和计数比较匹配时的电平由 PAINITVAL/PBINITVAL 和 CAPAVAL/CAPBVAL 定义。图为比较输出的动作例。



图 15-2 比较输出波形图

### 3、捕获输入

STMR1/2 都具有捕获输入功能，具备 2 组捕获输入寄存器（CMPA\_S、CMPB\_S），用于保存捕获到的计数值。设定端口控制寄存器（PCONRA/PCONRB）的 CAPA\_EN/CAPB\_EN 位为 1，对应端口的捕获输入功能就有效了。当设定了对应的捕获输入条件且该条件有效时，当前的计数值就被保存到相应的寄存器（CMPA\_S、CMPB\_S）中。每组捕获输入的条件可选 CHA 或 CHB 的上升沿，下降沿或上升下降沿，通过 CAPA\_MODE/CAPB\_MODE 来设定对应端口的捕获条件。

STMRxPRL\_S 和 STMRxPRH\_S 这两个寄存器决定了定时器内部计数器的溢出时间，捕获模

式状态下，建议两个寄存器都设置成 0xFF，捕获模式推荐使用锯齿波模式，捕获图参考下图。

捕获模式下读取基准寄存器 STMRxPRL\_S、STMRxPRH\_S、STMRxCMPAL\_S、STMRxCMPAH\_S、STMRxCMPBL\_S、STMRxCMPBH\_S（周期值和比较值）时，通过 STMRxCR 的 SEL\_SREG 设置来决定是读取影子寄存器还是基准寄存器的值。SEL\_SREG 设置成 0，读取基准寄存器的值（即捕获值），否则读取的是影子寄存器的值。捕获模式下写比较值影子寄存器没有意义。



图 15-3 捕获模式波形

#### 14.1.2. 时钟源选择

STMR1/2 的计数时钟可以有以下几种选择：

- 系统时钟 (SYSCLK)
- 内部低速RC振荡器 32kHz时钟
- 外部晶振（计数时钟为外部晶振/2）
- CHA/ CHB

时钟分频 1-16 可选，可对内部低速 RC、外部低速 RC、CHA、CHB 上升沿，下降沿，上升下降沿可选计数。

### 14.1.3. 计数方向

STMR1/2 的计数器计数方向可通过软件方式改变。不同波形模式时，改变计数方向的方法略有不同。

#### 14.1.3.1. 锯齿波计数方向

锯齿波模式时，计数方向可在计数器计数中或停止时设定。

在递加计数中时，设定 STMRxCR.DIR=0（递减计数），则计数器计数到上溢后变为递减计数模式；在递减计数中时，设定 STMRxCR.DIR=1（递加计数），则计数器计数到下溢后变为递加计数模式。

在计数停止时，设定 STMRxCR.DIR 位。则计数开始后，STMRxCR.DIR 的值立即更新。

**Note:** 在计数模式开启状态下改变 STMRxCR.DIR 的值，如果 CR 寄存器有其他位需要配置，请配置好其它位之后最后配置 DIR 位。或者不使用（或约与与约），配置 CR 寄存器。

修改 DIR 值时如果同时修改周期、比较值，可能会出现需要等待按照原周期原计数至顶部或谷底溢出（根据 DIR 方向决定）才会按照新修改的周期和比较值进行。

#### 14.1.3.2. 三角波计数方向

三角波模式时，计数方向只能在计数器停止时设定。在计数中设定计数方向无效。在计数停止时，设定 STMRxCR.DIR 位，立即生效。

#### 14.1.4. 数字滤波

STMR1/2 的 CHA、CHB 端口输入都有数字滤波功能。可通过设定 STMRxPCONRA.PA\_FILTER\_EN/STMRxPCONRB.PB\_FILTER\_EN 开启对应端口的滤波功能。滤波时钟为计数器当前工作时钟。

在滤波采样基准时钟采样到端口上 3 次一致的电平时，该电平被当作有效电平传送到模块内部；小于 3 次一致的电平会被当作外部干扰滤掉，不传送到模块内部。其动作例如所示。

数字滤波也用于对电压比较器传过来的信号滤波，通过 STMR1\_CR.THA\_FILTER\_EN/STMR1\_CR.THB\_FILTER\_EN 开启，此时滤波时钟为系统时钟。



图 15-4 数字滤波波形图

#### 14.1.5. 软件同步

STMR1/2 可通过设定软件同步启动寄存器 SSTAR (STMR\_ALLCON[3])，实现目标 STMR1/2 的同步启动。



图 15-5 同步启动和停止波形图

#### 14.1.5.1. 软件同步停止

STMR1/2 可通过设定软件同步停止寄存器 SSTPR (STMR\_ALLCON[4])，实现目标 STMR1/2 的同步停止，此时计数器处于暂停状态，对同步启动寄存器 SSTAR (STMR\_ALLCON[3]) 写 1 可以继续计数。

#### 14.1.5.2. 软件同步清零

STMR1/2 可通过设定软件同步清零寄存器 (STMR\_ALLCON[5])，实现目标 STMR1/2 的同步清零，此时计数器会复位到初始状态。

若设定 STMR\_ALLCON[3]，即可实现 STMR1/2 的软件同步启动。

软件同步动作相关寄存器是一组独立于 STMR1/2 外、各个 STMR 间共用的寄存器，这组寄存器的各个位只在写 1 时有效，写 0 无效。

#### 14.1.6. 缓存功能

缓存动作是指在发生更新事件时，发生以下事件：

PR={PRH, PRL}； CMPA={CMPAH, CMPAL}； CMPB={CMPBH, CMPBL}；

- a. 通用周期基准值影子寄存器 PR 的值自动传送到通用周期基准值寄存器 PR\_S ( {PRH\_S, PRL\_S} ) 中；
- b. 通用比较基准值影子寄存器 (CMPA、CMPB) 的值自动传送到通用比较基准值寄存器 (CMPA\_S、CMPB\_S) 中 (比较输出时)；
- c. 通用比较基准值寄存器 (CMPA\_S、CMPB\_S) 的值自动传送到通用比较基准值影子寄存器 (CMPA、CMPB) 中 (捕获输入时)；

如图所示，是比较输出动作时、通用比较基准值寄存器的单缓存方式的时序图。从中可以看到，在计数期间改变通用比较基准值寄存器 (CMPA\_S) 的值可以调整输出占空比，改变通用周期基准值寄存器 (PR) 的值可以调整输出周期。



图 15-6 自动装载波形图

#### 14.1.6.1. 缓存传送时间点

周期基准值缓存传送时间点为锯齿波时递加计数上溢点或递减计数下溢点。

三角波模式, 缓存传送发生在 (CNT=PR\_S) 上溢点或 (CNT=0) 下溢点。

三角波 A 模式时, 缓存传送发生在计数下溢点。

三角波 B 模式时, 缓存传送发生在计数下溢点和计数上溢点。

捕获输入动作缓存传送时间点为捕获输入动作时。

在计数模式启动 (STMRxCR.TMREN) 以及正常的比较期间若有清零动作产生时, 通用周期基准值、通用比较基准值、等会根据相应的缓存动作设定状况发生一次缓存传送 (更新事件)。

#### 14.1.7. 通用 PWM 输出

##### 14.1.7.1. 独立 PWM 输出

每个定时器的 2 个端口 CHA、CHB 能独立的输出 PWM 波。如图所示, 定时器 CHA 端口输出 PWM 波。



图 15-7 定时器 CHA 端口输出 PWM

#### 14.1.7.2. 互补 PWM 输出

CHA 端口和 CHB 端口，在不同的模式下通过设定端口的极性可组合输出互补 PWM 波形。

软件设定 CMPB\_S 互补 PWM 输出。

软件设定 CMPB\_S 互补 PWM 输出是指在锯齿波模式和三角波 A 模式、三角波 B 模式下，通过设定相反的输出极性，形成互补 PWM 输出。用于 CHB 端口波形输出的通用比较基准值寄存器（CMPB\_S）的值由寄存器（CMPB）直接设定，与通用比较基准值寄存器（CMWA\_S）的值没有直接关系。下图为软件设定 CMPB\_S 互补 PWM 波的示例。



图 15-8 软件设定 CMPB\_S 互补 PWM 波的示例

#### 硬件设定 CMPB\_S 互补 PWM 输出

硬件设定 CMPB\_S 互补 PWM 输出是指在三角波 A 模式、三角波 B 模式下，用于 CHB 端口波形输出的通用比较基准值寄存器（CMWA\_S）的值由通用比较基准值寄存器（CMWA\_S）减去死区时间基准值寄存器（DTUA）的值运算决定。图为硬件设定 CMPB\_S 互补 PWM 波输出例。死区时间基准值寄存器（DTUA）为 8bit，调整范围为 0~255。



图 15-9 带死区互补波形图

#### 14.1.8. 周期间隔响应

STMR1/2 的通用比较基准值寄存器 (CMPA\_S, CMPB\_S) , 在计数比较匹配时可分别产生专用有效请求信号 (CMPA\_ACK/CMPB\_ACK) 。

该请求信号可以每间隔几个周期后产生一次有效的请求信号。通过设定有效周期寄存器 (STMRxVPERR) 的 STMRxVPERR.PCNTS 位来指定每隔多少个周期请求信号有效一次，其它周期内即使计数值和比较基准值寄存器 CMPA\_S 或 CMPB\_S 的值相等，也不会输出有效的请求信号。图所示是周期间隔有效请求信号的动作例。

CHA/ CHB 的比较值匹配的请求信号分别输出。



图 15-10 周期间隔有效请求信号的动作波形图

#### 14.1.9. 保护机制

STMRx 可以对端口的输出状态进行保护控制。

STMRx 有 2 个共用的端口输入无效事件（来自模拟比较器，或者软件配置），每个接口上选通的异常状况事件可从刹车控制设定，当这些接口上监测到异常状况时，可以实现对通用 PWM 输出的控制。

端口在正常输出期间，若监测到从刹车控制过来的刹车事件，则端口的输出状态可变为预先设定好的状态。通用 PWM 输出端口在刹车控制异常事件发生时，端口状态可以变为输出高阻态、输出低电平或输出高电平（STMRxVPERR.BRAKEA\_VAL/ STMRxDTR.BRAKEB\_VAL 的设定决定）。

例如，若设定 BRAKEA\_VAL=2' b10 时，则在 CHA 端口正常输出期间，若产生刹车事件，则 CHA 端口上输出变为高阻态。

**Note:** 软件单独刹车 CHA，请设置 STMRxVPERR.BRAKEA\_SF；单独刹车 CHB 请设置

STMRxDTR.BRAKEB\_SF;将这两个寄存器设置为1，配合T1A\_EN、T1B\_EN使能则是软件刹车信号有效。STMRx\_BRAKE.T1A\_AOE/TIB\_AOE设置是软件复位，还是硬件复位，BRAKEA\_VAL / BRAKEB\_VAL位设置输出端输出状态。

#### 14.1.10. 中断说明

STMR1/2各含有4类共计6个中断。分别是2个通用计数比较匹配中断（含2个捕获输入中断）、2个计数周期匹配中断、2个刹车保护中断。

#### 14.1.11. 刹车保护

发生刹车事件时（来自电压比较器），硬件自动将端口状态改变为预设状态（高电平、低电平、高阻态）。

#### 14.1.12. 内部互连

- 电压比较器可以触发刹车功能。

#### 14.1.13. 红外功能

高级Timer2通道A的PWM与基本Timer2的PWM组合可以作为红外发生器使用。通过将SYS\_CON2[3]置1，使能红外功能。此时，基本Timer2作为载波PWM，高级Timer2通道A作为调制PWM，通过软件判断红外码为1或者0，更改高级Timer2通道A的周期和比较值影子寄存器，进行红外调制。结果通过Timer2的PWM输出到GPIO。

## 14.2. 模块框图



图 15-11 高级 Timer 模块框架图

## 14.3. 寄存器列表

表 15-1 STimer 寄存器列表

| Address    | Register Name | Description                                    |
|------------|---------------|------------------------------------------------|
| 0xC8 (SFR) | STMR1_CNTL    | STMR1 Count Low Register                       |
| 0xC9 (SFR) | STMR1_CNTH    | STMR1 Count High Register                      |
| 0xCA (SFR) | STMR1_PRL     | STMR1 Period Low Register                      |
| 0xCB (SFR) | STMR1_PRH     | STMR1 Period High Register                     |
| 0xCC (SFR) | STMR1_CMPAL   | STMR1 Channel A Comparison Value Low Register  |
| 0xCD (SFR) | STMR1_CMPAH   | STMR1 Channel A Comparison Value High Register |
| 0xCE (SFR) | STMR1_CMPBL   | STMR1 Channel B Comparison Value Low Register  |
| 0xCF (SFR) | STMR1_CMPBH   | STMR1 Channel B Comparison Value High Register |
| 0xD1 (SFR) | STMR1_CR      | STMR1 Control Register                         |
| 0xD2 (SFR) | STMR1_FCONR   | STMR1 Time Control Register                    |
| 0xD3 (SFR) | STMR1_VPERR   | STMR1 Count Period Register                    |

|            |              |                                                |
|------------|--------------|------------------------------------------------|
| 0xD4 (SFR) | STMR1_DTUA   | STMR1 DeadTime Register                        |
| 0xD5 (SFR) | STMR1_BRAKE  | STMR1 Brake Control Register                   |
| 0xD6 (SFR) | STMR1_DTR    | STMR1 DeadTime Control Register                |
| 0xD7 (SFR) | STMR1_PCONRA | STMR1 Channel A Control Register               |
| 0xD8 (SFR) | STMR1_PCONRB | STMR1 Channel B Control Register               |
| 0xD9 (SFR) | STMR1_IE     | STMR1 Interrupt Enable Register                |
| 0xDA (SFR) | STMR1_SR     | STMR1 Interrupt Flag Register                  |
| 0xDB (SFR) | STMR2_CNTL   | STMR2 Count Low Register                       |
| 0xDC (SFR) | STMR2_CNTH   | STMR2 Count High Register                      |
| 0xDD (SFR) | STMR2_PRL    | STMR2 Period Low Register                      |
| 0xDE (SFR) | STMR2_PRH    | STMR2 Period High Register                     |
| 0xDF (SFR) | STMR2_CMPAL  | STMR2 Channel A Comparison Value Low Register  |
| 0xE1 (SFR) | STMR2_CMPAH  | STMR2 Channel A Comparison Value High Register |
| 0xE2 (SFR) | STMR2_CMPBL  | STMR2 Channel B Comparison Value Low Register  |
| 0xE3 (SFR) | STMR2_CMPBH  | STMR2 Channel B Comparison Value High Register |
| 0xE4 (SFR) | STMR2_CR     | STMR2 Control Register                         |
| 0xE5 (SFR) | STMR2_FCONR  | STMR2 Time Control Register                    |
| 0xE6 (SFR) | STMR2_VPERR  | STMR2 Count Period Register                    |
| 0xE7 (SFR) | STMR2_DTUA   | STMR2 DeadTime Register                        |
| 0xE8 (SFR) | STMR2_BRAKE  | STMR2 Brake Control Register                   |
| 0xE9 (SFR) | STMR2_DTR    | STMR2 DeadTime Control Register                |
| 0xEA (SFR) | STMR2_PCONRA | STMR2 Channel A Control Register               |
| 0xEB (SFR) | STMR2_PCONRB | STMR2 Channel B Control Register               |
| 0xEC (SFR) | STMR2_IE     | STMR2 Interrupt Enable Register                |

|            |             |                               |
|------------|-------------|-------------------------------|
| 0xED (SFR) | STMR2_SR    | STMR2 Interrupt Flag Register |
| 0xF5 (SFR) | STMR_ALLCON | STMR ALL Control Register     |

## 14.4. 寄存器详细说明

### 14.4.1. STMR1\_CR

Addr = 0xD1 (SFR)

| Bit(s) | Name        | Description                                                                                                                                                    | R/W | Reset |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7      | THBFILTEREN | <p>STMR1 刹车输入 CHB 滤波控制<br/>           0x0: 刹车输入 CHB 关数字滤波<br/>           0x1: 刹车输入 CHB 开数字滤波<br/> <b>Note:</b> STMR1/2 共用, 只在 STMR1 设定, STMR2 共用 STMR1 设定。</p> | RW  | 0x0   |
| 6      | THAFILTEREN | <p>STMR1 刹车输入 CHA 滤波控制<br/>           0x0: 刹车输入 CHA 关数字滤波<br/>           0x1: 刹车输入 CHA 开数字滤波<br/> <b>Note:</b> STMR1/2 共用, 只在 STMR1 设定, STMR2 共用 STMR1 设定。</p> | RW  | 0x0   |
| 5      | -           | -                                                                                                                                                              | -   | -     |
| 4      | SELSREG     | <p>STMR1 读影子寄存器控制<br/>           0x0: 读取寄存器 PR/CMPA/CMPB 得到 PR_S/CMPA_S/CMPB_S 寄存器的值<br/>           0x1: 读取寄存器 PR/CMPA/CMPB 得到 PR/CMPA/CMPB 寄存器的值</p>          | RW  | 0x0   |
| 3      | DIR         | <p>STMR1 计数方向控制<br/>           0x0: 向下计数<br/>           0x1: 向上计数</p>                                                                                          | RW  | 0x1   |
| 2:1    | MODE        | <p>STMR1 计数器计数模式<br/>           0x0: 锯齿波计数模式<br/>           0x1: 三角波 A 计数模式</p>                                                                                | RW  | 0x0   |

|   |       |                                                      |    |     |
|---|-------|------------------------------------------------------|----|-----|
|   |       | 0x2: 三角波 B 计数模式<br>0x3: 保留                           |    |     |
| 0 | TMREN | STMR1 计数使能控制<br>0x0: 关闭 STMR1 计数<br>0x1: 打开 STMR1 计数 | RW | 0x0 |

#### 14.4.2. STMR1\_FCONR

Addr = 0xD2 (SFR)

| Bit(s) | Name   | Description                                                                                  | R/W | Reset |
|--------|--------|----------------------------------------------------------------------------------------------|-----|-------|
| 7:6    | INCSEL | STMR1 计数源<br>0x0: SYS_CLK<br>0x1: PIN_SEL 上升沿<br>0x2: PIN_SEL 下降沿<br>0x3: PIN_SEL 边沿 (上升和下降) | RW  | 0x0   |
| 5:4    | PINSEL | STMR1 计数时钟源<br>0x0: XOSCM/2<br>0x1: 32KHz RC<br>0x2: CHA 输入<br>0x3: CHB 输入                   | RW  | 0x0   |
| 3:0    | PREDIV | STMR1 计数预分频<br>0~15 对应 1~16 分频                                                               | RW  | 0x0   |

#### 14.4.3. STMR1\_CNTL

Addr = 0xC8 (SFR)

| Bit(s) | Name      | Description      | R/W | Reset |
|--------|-----------|------------------|-----|-------|
| 7:0    | STMR1CNTL | STMR1 计数寄存器低 8 位 | RW  | 0x0   |

#### 14.4.4. STMR1\_CNTH

Addr = 0xC9 (SFR)

| Bit(s) | Name      | Description      | R/W | Reset |
|--------|-----------|------------------|-----|-------|
| 7:0    | STMR1CNTH | STMR1 计数寄存器高 8 位 | RW  | 0x0   |

#### 14.4.5. STMR1\_PRL

Addr = 0xCA (SFR)

| Bit(s) | Name     | Description      | R/W | Reset |
|--------|----------|------------------|-----|-------|
| 7:0    | STMR1PRL | STMR1 周期寄存器低 8 位 | RW  | 0xFF  |

#### 14.4.6. STMR1\_PRH

Addr = 0xCB (SFR)

| Bit(s) | Name     | Description      | R/W | Reset |
|--------|----------|------------------|-----|-------|
| 7:0    | STMR1PRH | STMR1 周期寄存器高 8 位 | RW  | 0xFF  |

#### 14.4.7. STMR1\_CMPAL

Addr = 0xCC (SFR)

| Bit(s) | Name       | Description           | R/W | Reset |
|--------|------------|-----------------------|-----|-------|
| 7:0    | STMR1CMPAL | STMR1 CHA 比较值寄存器低 8 位 | RW  | 0x0   |

#### 14.4.8. STMR1\_CMPAH

Addr = 0xCD (SFR)

| Bit(s) | Name       | Description           | R/W | Reset |
|--------|------------|-----------------------|-----|-------|
| 7:0    | STMR1CMPAH | STMR1 CHA 比较值寄存器高 8 位 | RW  | 0x0   |

#### 14.4.9. STMR1\_CMPBL

Addr = 0xCE (SFR)

| Bit(s) | Name       | Description           | R/W | Reset |
|--------|------------|-----------------------|-----|-------|
| 7:0    | STMR1CMPBL | STMR1 CHB 比较值寄存器低 8 位 | RW  | 0x0   |

#### 14.4.10. STMR1\_CMPBH

Addr = 0xCF (SFR)

| Bit(s) | Name       | Description           | R/W | Reset |
|--------|------------|-----------------------|-----|-------|
| 7:0    | STMR1CMPBH | STMR1 CHB 比较值寄存器高 8 位 | RW  | 0x0   |

#### 14.4.11. STMR1\_VPERR

Addr = 0xD3 (SFR)

| Bit(s) | Name      | Description                                                                                                                             | R/W | Reset |
|--------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7      | BRAKEASF  | STMR1 CHA 软件刹车信号<br>0x0: CHA 软件刹车信号无效<br>0x1: CHA 软件刹车信号有效                                                                              | RW  | 0x0   |
| 6:5    | BRAKEAVAL | STMR1 CHA 刹车输出值<br>0x0: 刹车事件有效时, CHA PWM 输出 0<br>0x1: 刹车事件有效时, CHA PWM 输出 1<br>0x2: 刹车事件有效时, CHA PWM 输出关闭<br>0x3: 刹车事件有效时, CHA PWM 输出关闭 | RW  | 0x0   |
| 4:3    | PCNTE     | STMR1 周期间隔响应计数条件                                                                                                                        | RW  | 0x0   |

|     |       |                                                                                                                                                                         |    |     |
|-----|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|
|     |       | 0x0: 周期间隔功能无效<br>0x1: 锯齿波上或下溢点或三角波波谷<br>0x2: 锯齿波上或下溢点或三角波波峰<br>0x3: 锯齿波上或下溢点或三角波波峰和波谷                                                                                   |    |     |
| 2:0 | PCNTS | STMR1 周期间隔响应时长<br><br>0x0: 1 个周期响应一次<br>0x1: 2 个周期响应一次<br>0x2: 4 个周期响应一次<br>0x3: 8 个周期响应一次<br>0x4: 16 个周期响应一次<br>0x5: 32 个周期响应一次<br>0x6: 64 个周期响应一次<br>0x7: 128 个周期响应一次 | RW | 0x0 |

#### 14.4.12. STMR1\_DTUA

Addr = 0xD4 (SFR)

| Bit(s) | Name      | Description     | R/W | Reset |
|--------|-----------|-----------------|-----|-------|
| 7:0    | STMR1DTUA | STMR1 死区时间设定寄存器 | RW  | 0x0   |

#### 14.4.13. STMR1\_BRAKE

Addr = 0xD5 (SFR)

| Bit(s) | Name   | Description                                                                                                                                                         | R/W | Reset |
|--------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7      | T1BMOE | STMR1 CHB 刹车事件后, PWM 正常输出标志<br><br>0x1: CHB PWM 恢复正常输出<br>0x0: CHB PWM 按照刹车配置输出<br><br><b>Note:</b> 刹车事件有效时, 会立即被同步清零; 当刹车有效信号消失后, 根据 T1BAOE 的选择, 通过软件置 1 或硬件自动置 1。 | RW  | 0x1   |

|   |        |                                                                                                                                                             |    |     |
|---|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|
| 6 | T1BAOE | STMR1 CHB PWM 正常输出标志控制位<br>0x0: 有效刹车事件后, T1BMOE 只能软件置 1<br>0x1: 有效刹车事件后, T1BMOE 可被软件和溢出置 1                                                                  | RW | 0x0 |
| 5 | T1BSEL | STMR1 CHB 刹车源<br>0x0: CHB 选择模拟比较器 0 输出作为刹车源<br>0x1: CHB 选择模拟比较器 1 输出作为刹车源                                                                                   | RW | 0x0 |
| 4 | T1BEN  | STMR1 CHB 刹车使能<br>0x0: CHB 刹车不使能<br>0x1: CHB 刹车使能                                                                                                           | RW | 0x0 |
| 3 | T1AMOE | STMR1 CHA 刹车事件后, PWM 正常输出标志<br>0x0: CHA PWM 按照刹车配置输出<br>0x1: CHA PWM 恢复正常输出<br><b>Note:</b> 刹车事件有效时, 会立即被同步清零; 当刹车有效信号消失后, 根据 T1AAOE 的选择, 通过软件置 1 或硬件自动置 1。 | RW | 0x1 |
| 2 | T1AAOE | STMR1 CHA PWM 正常输出标志控制位<br>0x0: 有效刹车事件后, T1AMOE 只能软件置 1<br>0x1: 有效刹车事件后, T1AMOE 可被软件和溢出置 1                                                                  | RW | 0x0 |
| 1 | T1ASEL | STMR1 CHA 刹车源<br>0x0: CHA 选择模拟比较器 0 输出作为刹车源<br>0x1: CHA 选择模拟比较器 1 输出作为刹车源                                                                                   | RW | 0x0 |
| 0 | T1AEN  | STMR1 CHA 刹车使能<br>0x0: CHA 刹车不使能<br>0x1: CHA 刹车使能                                                                                                           | RW | 0x0 |

#### 14.4.14. STMR1\_DTR

Addr = 0xD6 (SFR)

| Bit(s) | Name | Description | R/W | Reset |
|--------|------|-------------|-----|-------|
|        |      |             |     |       |

|     |          |                                                                                                                                         |    |     |
|-----|----------|-----------------------------------------------------------------------------------------------------------------------------------------|----|-----|
| 7   | BRAKEBSF | STMR1 CHB 软件刹车信号<br>0x0: CHB 软件刹车信号无效<br>0x1: CHB 软件刹车信号有效                                                                              | RW | 0x0 |
| 6:5 | BRAKEVAL | STMR1 CHB 刹车输出值<br>0x0: 刹车事件有效时, CHB PWM 输出 0<br>0x1: 刹车事件有效时, CHB PWM 输出 1<br>0x2: 刹车事件有效时, CHB PWM 输出关闭<br>0x3: 刹车事件有效时, CHB PWM 输出关闭 | RW | 0x0 |
| 4   | HWCPWM   | STMR1 互补模式下硬件设定 CMPB_S 寄存器使能<br>0x0: 硬件设定 CMPB_S 寄存器不使能<br>0x1: 硬件设定 CMPB_S 寄存器使能                                                       | RW | 0x0 |
| 3   | DTBHO    | STMR1 互补模式下 CHB 死区输出值<br>0x1: CHB PWM 死区输出关闭<br>0x0: CHB PWM 死区正常输出                                                                     | RW | 0x0 |
| 2   | DTBEN    | STMR1 CHB 死区使能<br>0x0: 死区设置无效<br>0x1: 死区设置有效                                                                                            | RW | 0x0 |
| 1   | DTAHO    | STMR1 互补模式下 CHA 死区输出值<br>0x0: CHA PWM 死区正常输出<br>0x1: CHA PWM 死区输出关闭                                                                     | RW | 0x0 |
| 0   | DTAEN    | STMR1 CHA 死区使能<br>0x0: 死区设置无效<br>0x1: 死区设置有效                                                                                            | RW | 0x0 |

#### 14.4.15. STMR1\_PCONRA

Addr = 0xD7 (SFR)

| Bit(s) | Name      | Description                                                                     | R/W | Reset |
|--------|-----------|---------------------------------------------------------------------------------|-----|-------|
| 7      | PAINITVAL | STMR1 CHA PWM 初始输出值<br>0x0: CHA 计数使能后 PWM 初始状态为 0<br>0x1: CHA 计数使能后 PWM 初始状态为 1 | RW  | 0x0   |

|     |            |                                                                                                                                  |    |     |
|-----|------------|----------------------------------------------------------------------------------------------------------------------------------|----|-----|
| 6:5 | CMPAVAL    | STMR1 CHA PWM 输出值<br>0x0: 计数值小于 CHA 比较值输出 1, 大于输出 0<br>0x1: 计数值大于 CHA 比较值输出 1, 小于输出 0<br>0x2: 计数值等于 CHA 比较值, 输出翻转<br>0x3: 输出保持不变 | RW | 0x0 |
| 4   | PAENO      | STMR1 CHA PWM 输出使能<br>0x0: CHA PWM 输出不使能<br>0x1: CHA PWM 输出使能                                                                    | RW | 0x0 |
| 3   | PAFILTEREN | STMR1 CHA 输入滤波使能<br>0x0: CHA 输入信号不滤波<br>0x1: CHA 输入信号滤波                                                                          | RW | 0x0 |
| 2:1 | CAPAMODE   | STMR1 CHA 捕获点选择<br>0x0: 不捕获<br>0x1: 捕获上升沿<br>0x2: 捕获下降沿<br>0x3: 捕获边沿 (上升沿和下降沿)                                                   | RW | 0x0 |
| 0   | CAPAEN     | STMR1 CHA 捕获模式使能<br>0x0: 捕获模式不使能<br>0x1: 捕获模式使能                                                                                  | RW | 0x0 |

#### 14.4.16. STMR1\_PCONRB

Addr = 0xD8 (SFR)

| Bit(s) | Name      | Description                                                                                                                      | R/W | Reset |
|--------|-----------|----------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7      | PBINITVAL | STMR1 CHB PWM 初始输出值<br>0x0: CHB 计数使能后 PWM 初始状态为 0<br>0x1: CHB 计数使能后 PWM 初始状态为 1                                                  | RW  | 0x0   |
| 6:5    | CMPBVAL   | STMR1 CHB PWM 输出值<br>0x0: 计数值小于 CHB 比较值输出 1, 大于输出 0<br>0x1: 计数值大于 CHB 比较值输出 1, 小于输出 0<br>0x2: 计数值等于 CHB 比较值, 输出翻转<br>0x3: 输出保持不变 | RW  | 0x0   |

|     |            |                                                                               |    |     |
|-----|------------|-------------------------------------------------------------------------------|----|-----|
| 4   | PBENO      | STMR1 CHB PWM 输出使能<br>0x0: CHB PWM 输出不使能<br>0x1: CHB PWM 输出使能                 | RW | 0x0 |
| 3   | PBFILTEREN | STMR1 CHB 输入滤波使能<br>0x0: CHB 输入信号不滤波<br>0x1: CHB 输入信号滤波                       | RW | 0x0 |
| 2:1 | CAPBMODE   | STMR1 CHB 捕获点选择<br>0x0: 不捕获<br>0x1: 捕获上升沿<br>0x2: 捕获下降沿<br>0x3: 捕获边沿（上升沿和下降沿） | RW | 0x0 |
| 0   | CAPBEN     | STMR1 CHB 捕获模式使能<br>0x0: 捕获模式不使能<br>0x1: 捕获模式使能                               | RW | 0x0 |

#### 14.4.17. STMR1\_IE

Addr = 0xD9 (SFR)

| Bit(s) | Name     | Description                                                                                   | R/W | Reset |
|--------|----------|-----------------------------------------------------------------------------------------------|-----|-------|
| 7:6    | -        | -                                                                                             | -   | -     |
| 5      | BRAKEBIE | STMR1 CHB 刹车中断使能<br>0x0: CHB 刹车中断不使能<br>0x1: CHB 刹车中断使能                                       | RW  | 0x0   |
| 4      | BRAKEAIE | STMR1 CHA 刹车中断使能<br>0x0: CHA 刹车中断不使能<br>0x1: CHA 刹车中断使能                                       | RW  | 0x0   |
| 3      | CMPBIE   | STMR1 计数值等于 CHB 比较值/发生捕获中断使能<br>0x0: 计数值等于 CHB 比较值或发生捕获，中断不使能<br>0x1: 计数值等于 CHB 比较值或发生捕获，中断使能 | RW  | 0x0   |
| 2      | CMPAIE   | STMR1 计数值等于 CHA 比较值/发生捕获中断使能                                                                  | RW  | 0x0   |

|   |      |                                                                                                |    |     |
|---|------|------------------------------------------------------------------------------------------------|----|-----|
|   |      | 0x0: 计数值等于 CHA 比较值或发生捕获，中断不使能<br>0x1: 计数值等于 CHA 比较值或发生捕获，中断使能                                  |    |     |
| 1 | UDIE | STMR1 计数值等于 0 中断使能<br>0x0: 计数值等于 0 中断不使能<br>0x1: 计数值等于 0 中断使能<br><b>Note:</b> 锯齿波模式向上计数没有 0 中断 | RW | 0x0 |
| 0 | OVIE | STMR1 计数值等于周期中断使能<br>0x0: 计数值等于周期中断不使能<br>0x1: 计数值等于周期中断使能<br><b>Note:</b> 锯齿波模式向下计数没有周期中断     | RW | 0x0 |

#### 14.4.18. STMR1\_SR

Addr = 0xDA (SFR)

| Bit(s) | Name     | Description                                                                                                                   | R/W | Reset |
|--------|----------|-------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7:6    | -        | -                                                                                                                             | -   | -     |
| 5      | BRAKEBIF | STMR1 CHB 刹车中断标志<br>0x0: CHB 有效刹车没有发生<br>0x1: CHB 有效刹车已经发生<br><b>Note:</b> 写 1 清零，写 0 无效。读取为标志状态。                             | RW  | 0x0   |
| 4      | BRAKEAIF | STMR1 CHA 刹车中断标志<br>0x0: CHA 有效刹车没有发生<br>0x1: CHA 有效刹车已经发生<br><b>Note:</b> 写 1 清零，写 0 无效。读取为标志状态。                             | RW  | 0x0   |
| 3      | CMPBIF   | STMR1 计数值等于 CHB 比较值/发生捕获中断标志<br>0x0: 计数值等于 CHB 比较值或捕获没有发生<br>0x1: 计数值等于 CHB 比较值或捕获已经发生<br><b>Note:</b> 写 1 清零，写 0 无效。读取为标志状态。 | RW  | 0x0   |
| 2      | CMPAIF   | STMR1 计数值等于 CHA 比较值/发生捕获中断标志                                                                                                  | RW  | 0x0   |

|   |      |                                                                                                      |    |     |
|---|------|------------------------------------------------------------------------------------------------------|----|-----|
|   |      | 0x0: 计数值等于 CHA 比较值或捕获没有发生<br>0x1: 计数值等于 CHA 比较值或捕获已经发生<br><b>Note:</b> 写 1 清零, 写 0 无效。读取为标志状态。       |    |     |
| 1 | UDIF | STMR1 计数值等于 0 中断标志<br>0x0: 计数值等于 0 没有发生<br>0x1: 计数值等于 0 已经发生<br><b>Note:</b> 写 1 清零, 写 0 无效。读取为标志状态。 | RW | 0x0 |
| 0 | OVIF | STMR1 计数值等于周期中断标志<br>0x0: 计数值等于周期没有发生<br>0x1: 计数值等于周期已经发生<br><b>Note:</b> 写 1 清零, 写 0 无效。读取为标志状态。    | RW | 0x0 |

#### 14.4.19. STMR2\_CR

Addr = 0xE4 (SFR)

| Bit(s) | Name    | Description                                                                                                                      | R/W | Reset |
|--------|---------|----------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7:6    | -       | -                                                                                                                                | -   | -     |
| 5      | CAPTMR1 | STMR2 捕捉 STMR1 刹车滤波<br>0x0: STMR2 不捕捉 STMR1 刹车滤波控制<br>0x1: STMR2 捕捉 STMR1 刹车滤波控制<br><b>Note:</b> 捕捉后 STMR2 刹车滤波和 STMR1 刹车滤波设置同步。 | RW  | 0x0   |
| 4      | SELSREG | STMR2 读影子寄存器控制<br>0x0: 读寄存器 PR/CMPA/CMPB 得到 PR_S/CMPA_S/CMPB_S 寄存器的值<br>0x1: 读寄存器 PR/CMPA/CMPB 得到 PR/CMPA/CMPB 寄存器的值             | RW  | 0x0   |
| 3      | DIR     | STMR2 计数方向<br>0x0: 向下计数<br>0x1: 向上计数                                                                                             | RW  | 0x1   |
| 2:1    | MODE    | STMR2 计数器计数模式<br>0x0: 锯齿波计数模式                                                                                                    | RW  | 0x0   |

|   |       |                                                   |    |     |
|---|-------|---------------------------------------------------|----|-----|
|   |       | 0x1: 三角波 A 计数模式<br>0x2: 三角波 B 计数模式<br>0x3: 保留     |    |     |
| 0 | TMREN | STMR2 计数使能<br>0x0: STMR2 计数不使能<br>0x1: STMR2 计数使能 | RW | 0x0 |

#### 14.4.20. STMR2\_FCONR

Addr = 0xE5 (SFR)

| Bit(s) | Name   | Description                                                                                  | R/W | Reset |
|--------|--------|----------------------------------------------------------------------------------------------|-----|-------|
| 7:6    | INCSEL | STMR2 计数源<br>0x0: SYS_CLK<br>0x1: PIN_SEL 上升沿<br>0x2: PIN_SEL 下降沿<br>0x3: PIN_SEL 边沿 (上升和下降) | RW  | 0x0   |
| 5:4    | PINSEL | STMR2 计数时钟源<br>0x0: XOSCM/2<br>0x1: 32KHz RC<br>0x2: CHA 输入<br>0x3: CHB 输入                   | RW  | 0x0   |
| 3:0    | PREDIV | STMR2 计数预分频<br>0~15 对应 1~16 分频                                                               | RW  | 0x0   |

#### 14.4.21. STMR2\_PRL

Addr = 0xDD (SFR)

| Bit(s) | Name     | Description      | R/W | Reset |
|--------|----------|------------------|-----|-------|
| 7:0    | STMR2PRL | STMR2 周期寄存器低 8 位 | RW  | 0xFF  |

#### 14.4.22. STMR2\_PRH

Addr = 0xDE (SFR)

| Bit(s) | Name     | Description      | R/W | Reset |
|--------|----------|------------------|-----|-------|
| 7:0    | STMR2PRH | STMR2 周期寄存器高 8 位 | RW  | 0xFF  |

#### 14.4.23. STMR2\_CMPAL

Addr = 0xDF (SFR)

| Bit(s) | Name       | Description           | R/W | Reset |
|--------|------------|-----------------------|-----|-------|
| 7:0    | STMR2CMPAL | STMR2 CHA 比较值寄存器低 8 位 | RW  | 0x0   |

#### 14.4.24. STMR2\_CMPAH

Addr = 0xE1 (SFR)

| Bit(s) | Name       | Description           | R/W | Reset |
|--------|------------|-----------------------|-----|-------|
| 7:0    | STMR2CMPAH | STMR2 CHA 比较值寄存器高 8 位 | RW  | 0x0   |

#### 14.4.25. STMR2\_CMPBL

Addr = 0xE2 (SFR)

| Bit(s) | Name       | Description           | R/W | Reset |
|--------|------------|-----------------------|-----|-------|
| 7:0    | STMR2CMPBL | STMR2 CHB 比较值寄存器低 8 位 | RW  | 0x0   |

#### 14.4.26. STMR2\_CMPBH

Addr = 0xE3 (SFR)

| Bit(s) | Name        | Description           | R/W | Reset |
|--------|-------------|-----------------------|-----|-------|
| 7:0    | STMR2_CMPBH | STMR2 CHB 比较值寄存器高 8 位 | RW  | 0x0   |

#### 14.4.27. STMR2\_VPERR

Addr = 0xE6 (SFR)

| Bit(s) | Name      | Description                                                                                                                                     | R/W | Reset |
|--------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7      | BRAKEASF  | STMR2 CHA 软件刹车信号<br>0x0: CHA 软件刹车信号无效<br>0x1: CHA 软件刹车信号有效                                                                                      | RW  | 0x0   |
| 6:5    | BRAKEAVAL | STMR2 CHA 刹车输出值<br>0x0: 刹车事件有效时, CHB PWM 输出 0<br>0x1: 刹车事件有效时, CHB PWM 输出 1<br>0x2: 刹车事件有效时, CHB PWM 输出关闭<br>0x3: 刹车事件有效时, CHB PWM 输出关闭         | RW  | 0x0   |
| 4:3    | PCNTE     | STMR2 周期间隔响应计数条件<br>0x0: 周期间隔功能无效<br>0x1: 锯齿波上或下溢点或三角波波谷<br>0x2: 锯齿波上或下溢点或三角波波峰<br>0x3: 锯齿波上或下溢点或三角波波峰和波谷                                       | RW  | 0x0   |
| 2:0    | PCNTS     | STMR2 周期间隔响应时长<br>0x0: 1 个周期响应一次<br>0x1: 2 个周期响应一次<br>0x2: 4 个周期响应一次<br>0x3: 8 个周期响应一次<br>0x4: 16 个周期响应一次<br>0x5: 32 个周期响应一次<br>0x6: 64 个周期响应一次 | RW  | 0x0   |

|  |  |                  |  |  |
|--|--|------------------|--|--|
|  |  | 0x7: 128 个周期响应一次 |  |  |
|--|--|------------------|--|--|

#### 14.4.28. STMR2\_DTUA

Addr = 0xE7 (SFR)

| Bit(s) | Name       | Description     | R/W | Reset |
|--------|------------|-----------------|-----|-------|
| 7:0    | STMR2_DTUA | STMR2 死区时间设定寄存器 | RW  | 0x0   |

#### 14.4.29. STMR2\_BRAKE

Addr = 0xE8 (SFR)

| Bit(s) | Name   | Description                                                                                                                                                 | R/W | Reset |
|--------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7      | T1BMOE | STMR2 CHB 刹车事件后, PWM 正常输出标志<br>0x0: CHB PWM 按照刹车配置输出<br>0x1: CHB PWM 恢复正常输出<br><b>Note:</b> 刹车事件有效时, 会立即被同步清零; 当刹车有效信号消失后, 根据 T1BAOE 的选择, 通过软件置 1 或硬件自动置 1。 | RW  | 0x1   |
| 6      | T1BAOE | STMR2 CHB PWM 正常输出标志控制位<br>0x0: 有效刹车事件后, T1BMOE 只能软件置 1<br>0x1: 有效刹车事件后, T1BMOE 可被软件和溢出置 1                                                                  | RW  | 0x0   |
| 5      | T1BSEL | STMR2 CHB 刹车源<br>0x0: CHB 选择模拟比较器 0 输出作为刹车源<br>0x1: CHB 选择模拟比较器 1 输出作为刹车源                                                                                   | RW  | 0x0   |
| 4      | T1BEN  | STMR2 CHB 刹车使能<br>0x0: CHB 刹车不使能<br>0x1: CHB 刹车使能                                                                                                           | RW  | 0x0   |
| 3      | T1AMOE | STMR2 CHA 刹车事件后, PWM 正常输出标志<br>0x1: CHA PWM 恢复正常输出                                                                                                          | RW  | 0x1   |

|   |        |                                                                                                       |    |     |
|---|--------|-------------------------------------------------------------------------------------------------------|----|-----|
|   |        | 0x0: CHA PWM 按照刹车配置输出<br><br><b>Note:</b> 刹车事件有效时，会立即被同步清零；当刹车有效信号消失后，根据 T1AAOE 的选择，通过软件置 1 或硬件自动置 1。 |    |     |
| 2 | T1AAOE | STMR2 CHA PWM 正常输出标志控制位<br><br>0x0: 有效刹车事件后，T1AMOE 只能软件置 1<br>0x1: 有效刹车事件后，T1AMOE 可被软件和溢出置 1          | RW | 0x0 |
| 1 | T1ASEL | STMR2 CHA 刹车源<br><br>0x0: CHA 选择模拟比较器 0 输出作为刹车源<br>0x1: CHA 选择模拟比较器 1 输出作为刹车源                         | RW | 0x0 |
| 0 | T1AEN  | STMR2 CHA 刹车使能<br><br>0x0: CHA 刹车不使能<br>0x1: CHA 刹车使能                                                 | RW | 0x0 |

#### 14.4.30. STMR2\_DTR

Addr = 0xE9 (SFR)

| Bit(s) | Name      | Description                                                                                                                             | R/W | Reset |
|--------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7      | BRAKEBSF  | STMR2 CHB 软件刹车信号<br><br>0x0: CHB 软件刹车信号无效<br>0x1: CHB 软件刹车信号有效                                                                          | RW  | 0x0   |
| 6:5    | BRAKEBVAL | STMR2 CHB 刹车输出值<br><br>0x0: 刹车事件有效时，CHB PWM 输出 0<br>0x1: 刹车事件有效时，CHB PWM 输出 1<br>0x2: 刹车事件有效时，CHB PWM 输出关闭<br>0x3: 刹车事件有效时，CHB PWM 输出关闭 | RW  | 0x0   |
| 4      | HWCPWM    | STMR2 互补模式下硬件设定 CMPB_S 寄存器使能<br><br>0x0: 硬件设定 CMPB_S 寄存器不使能<br>0x1: 硬件设定 CMPB_S 寄存器使能                                                   | RW  | 0x0   |
| 3      | DTBHO     | STMR2 互补模式下 CHB 死区输出值<br><br>0x0: CHB PWM 死区正常输出                                                                                        | RW  | 0x0   |

|   |       |                                                                            |    |     |
|---|-------|----------------------------------------------------------------------------|----|-----|
|   |       | 0x1: CHB PWM 死区输出关闭                                                        |    |     |
| 2 | DTBEN | <b>STMR2 CHB 死区使能</b><br>0x0: 死区设置无效<br>0x1: 死区设置有效                        | RW | 0x0 |
| 1 | DTAHO | <b>STMR2 互补模式下 CHA 死区输出值</b><br>0x1: CHA PWM 死区输出关闭<br>0x0: CHA PWM 死区正常输出 | RW | 0x0 |
| 0 | DTAEN | <b>STMR2 CHA 死区使能</b><br>0x0: 死区设置无效<br>0x1: 死区设置有效                        | RW | 0x0 |

#### 14.4.31. STMR2\_PCONRA

Addr = 0xEA (SFR)

| Bit(s) | Name       | Description                                                                                                                             | R/W | Reset |
|--------|------------|-----------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7      | PAINITVAL  | <b>STMR2 CHA PWM 初始输出值</b><br>0x0: CHA 计数使能后 PWM 初始状态为 0<br>0x1: CHA 计数使能后 PWM 初始状态为 1                                                  | RW  | 0x0   |
| 6:5    | CMPAVAL    | <b>STMR2 CHA PWM 输出值</b><br>0x0: 计数值小于 CHA 比较值输出 1, 大于输出 0<br>0x1: 计数值大于 CHA 比较值输出 1, 小于输出 0<br>0x2: 计数值等于 CHA 比较值, 输出翻转<br>0x3: 输出保持不变 | RW  | 0x0   |
| 4      | PAENO      | <b>STMR2 CHA PWM 输出使能</b><br>0x0: CHA PWM 输出不使能<br>0x1: CHA PWM 输出使能                                                                    | RW  | 0x0   |
| 3      | PAFILTEREN | <b>STMR2 CHA 输入滤波使能</b><br>0x0: CHA 输入信号不滤波<br>0x1: CHA 输入信号滤波                                                                          | RW  | 0x0   |
| 2:1    | CAPAMODE   | <b>STMR2 CHA 捕获点选择</b><br>0x0: 不捕获<br>0x1: 捕获上升沿                                                                                        | RW  | 0x0   |

|   |        |                                                 |    |     |
|---|--------|-------------------------------------------------|----|-----|
|   |        | 0x2: 捕获下降沿<br>0x3: 捕获边沿（上升沿和下降沿）                |    |     |
| 0 | CAPAEN | STMR2 CHA 捕获模式使能<br>0x0: 捕获模式不使能<br>0x1: 捕获模式使能 | RW | 0x0 |

#### 14.4.32. STMR2\_PCONRB

Addr = 0xEB (SFR)

| Bit(s) | Name       | Description                                                                                                                      | R/W | Reset |
|--------|------------|----------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7      | PBINITVAL  | STMR2 CHB PWM 初始输出值<br>0x0: CHB 计数使能后 PWM 初始状态为 0<br>0x1: CHB 计数使能后 PWM 初始状态为 1                                                  | RW  | 0x0   |
| 6:5    | CMPBVAL    | STMR2 CHB PWM 输出值<br>0x0: 计数值小于 CHB 比较值输出 1, 大于输出 0<br>0x1: 计数值大于 CHB 比较值输出 1, 小于输出 0<br>0x2: 计数值等于 CHB 比较值, 输出翻转<br>0x3: 输出保持不变 | RW  | 0x0   |
| 4      | PBENO      | STMR2 CHB PWM 输出使能<br>0x0: CHB PWM 输出不使能<br>0x1: CHB PWM 输出使能                                                                    | RW  | 0x0   |
| 3      | PBFILTEREN | STMR2 CHB 输入滤波使能<br>0x0: CHB 输入信号不滤波<br>0x1: CHB 输入信号滤波                                                                          | RW  | 0x0   |
| 2:1    | CAPBMODE   | STMR2 CHB 捕获点选择<br>0x0: 不捕获<br>0x1: 捕获上升沿<br>0x2: 捕获下降沿<br>0x3: 捕获边沿（上升沿和下降沿）                                                    | RW  | 0x0   |
| 0      | CAPBEN     | STMR2 CHB 捕获模式使能<br>0x0: 捕获模式不使能<br>0x1: 捕获模式使能                                                                                  | RW  | 0x0   |

#### 14.4.33. STMR2\_IE

Addr = 0xEC (SFR)

| Bit(s) | Name     | Description                                                                                    | R/W | Reset |
|--------|----------|------------------------------------------------------------------------------------------------|-----|-------|
| 7:6    | -        | -                                                                                              | -   | -     |
| 5      | BRAKEBIE | STMR2 CHB 刹车中断使能<br>0x0: CHB 刹车中断不使能<br>0x1: CHB 刹车中断使能                                        | RW  | 0x0   |
| 4      | BRAKEAIE | STMR2 CHA 刹车中断使能<br>0x0: CHA 刹车中断不使能<br>0x1: CHA 刹车中断使能                                        | RW  | 0x0   |
| 3      | CMPBIE   | STMR2 CHB 计数值等于比较值/发生捕获中断使能<br>0x0: 计数值等于 CHB 比较值或发生捕获, 中断不使能<br>0x1: 计数值等于 CHB 比较值或发生捕获, 中断使能 | RW  | 0x0   |
| 2      | CMPAIE   | STMR2 CHA 计数值等于比较值/发生捕获中断使能<br>0x0: 计数值等于 CHA 比较值或发生捕获, 中断不使能<br>0x1: 计数值等于 CHA 比较值或发生捕获, 中断使能 | RW  | 0x0   |
| 1      | UDIE     | STMR2 计数值等于 0 中断使能<br>0x0: 计数值等于 0 中断不使能<br>0x1: 计数值等于 0 中断使能<br><b>Note:</b> 锯齿波模式向上计数没有 0 中断 | RW  | 0x0   |
| 0      | OVIE     | STMR2 计数值等于周期中断使能<br>0x0: 计数值等于周期中断不使能<br>0x1: 计数值等于周期中断使能<br><b>Note:</b> 锯齿波模式向下计数没有周期中断     | RW  | 0x0   |

#### 14.4.34. STMR2\_SR

Addr = 0xED (SFR)

| Bit(s) | Name     | Description                                                                                                                        | R/W | Reset |
|--------|----------|------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7:6    | -        | -                                                                                                                                  | -   | -     |
| 5      | BRAKEBIF | <b>STMR2 CHB 刹车中断标志</b><br>0x0: CHB 有效刹车没有发生<br>0x1: CHB 有效刹车已经发生<br><b>Note:</b> 写 1 清零, 写 0 无效。读取为标志状态。                          | RW  | 0x0   |
| 4      | BRAKEAIF | <b>STMR2 CHA 刹车中断标志</b><br>0x0: CHA 有效刹车没有发生<br>0x1: CHA 有效刹车已经发生<br><b>Note:</b> 写 1 清零, 写 0 无效。读取为标志状态。                          | RW  | 0x0   |
| 3      | CMPBIF   | <b>STMR2 CHB 计数值等于比较值/发生捕获中断标志</b><br>0x0: CHB 计数值等于比较值或捕获没有发生<br>0x1: CHB 计数值等于比较值或捕获已经发生<br><b>Note:</b> 写 1 清零, 写 0 无效。读取为标志状态。 | RW  | 0x0   |
| 2      | CMPAIF   | <b>STMR2 CHA 计数值等于比较值/发生捕获中断标志</b><br>0x0: CHA 计数值等于比较值或捕获没有发生<br>0x1: CHA 计数值等于比较值或捕获已经发生<br><b>Note:</b> 写 1 清零, 写 0 无效。读取为标志状态。 | RW  | 0x0   |
| 1      | UDIF     | <b>STMR2 计数值等于 0 中断标志</b><br>0x0: 计数值等于 0 没有发生<br>0x1: 计数值等于 0 已经发生<br><b>Note:</b> 写 1 清零, 写 0 无效。读取为标志状态。                        | RW  | 0x0   |
| 0      | OVIF     | <b>STMR2 计数值等于周期中断标志</b><br>0x0: 计数值等于周期没有发生<br>0x1: 计数值等于周期已经发生<br><b>Note:</b> 写 1 清零, 写 0 无效。读取为标志状态。                           | RW  | 0x0   |

#### 14.4.35. STMR\_ALLCON

Addr = 0xF5 (SFR)

| Bit(s) | Name       | Description                            | R/W | Reset |
|--------|------------|----------------------------------------|-----|-------|
| 7:6    | -          | -                                      | -   | -     |
| 5      | SCLRR      | STMR1 和 STMR2 计数同步清零<br>写 1 清零, 写 0 无效 | WO  | 0x0   |
| 4      | SSTPR      | STMR1 和 STMR2 同步停止计数<br>写 1 有效, 写 0 无效 | WO  | 0x0   |
| 3      | SSTAR      | STMR1 和 STMR2 同步启动计数<br>写 1 有效, 写 0 无效 | WO  | 0x0   |
| 2      | TMR2CLRCNT | TMR2 计数清零<br>写 1 清零, 写 0 无效            | WO  | 0x0   |
| 1      | TMR1CLRCNT | TMR1 计数清零<br>写 1 清零, 写 0 无效            | WO  | 0x0   |
| 0      | TMROCLRCNT | TMRO 计数清零<br>写 1 清零, 写 0 无效            | WO  | 0x0   |

#### 14.5. 使用流程说明

- 选择计数模式，计数方向；
- 选择计数时钟源 (PIN\_SEL)，选择计数方式（上升沿，下降沿）INC\_SEL；
- 配置分频寄存器，周期寄存器；
- 选择打开捕获模式还是PWM输出模式；
- 如果选择捕获模式，请配置捕获模式相关寄存器；
- 如果选择PWM输出模式，请配置比较器寄存器以及其他PWM输出相关寄存器：包括死区以及刹车相关寄存器；
- 计数使能位置 1；

## 15.CRC16 模块

### 15.1. 功能概述

CRC16 功能特点如下：

- 支持CRC16-CCITT-FALSE/CRC16-XMODEM计算
- 每一个系统时钟周期计算 1byte数据
- 支持更改初值，实现对不同的CRC协议的支持

**Note:** 当FLASH使用CRC校验代码的时候，CRC模块暂时无法使用

### 15.2. 基本功能

CRC16-CCITT-FALSE 协议为  $x^{16}+x^{12}+x^5+1$ ，初始值为 0xffff，输入数据不取反，输出数据不取反，输出数据异或 0x0。

CRC16-XMODEM 协议为  $x^{16}+x^{12}+x^5+1$ ，初始值为 0x0，输入数据不取反，输出数据不取反，输出数据异或 0x0。

CRC16 模块没输入一次就进行 1byte 数据的并行 CRC 计算，对比于串行计算 CRC，大大提高了运算速度，CRC16 模块在使用的时候需要注意，在每次使用模块时需要使用 CRC\_REG 寄存器配置 CRC16 计算的初始值，初始值为 16 位，所以需要配置两次，初始值只能为 0xffff、0x0，与此同时，CRC16 的运算结果为 16 位，所以在读取结果的时候需要读取两次 CRC\_FIFO 寄存器，把两次读取的值拼接成一个 16 位的结果才是真正的 CRC16 的结果。

### 15.3. 模块框图



图 16-1 CRC16 结构框图

### 15.4. 寄存器列表

表 16-1 CRC 寄存器列表

| Address    | Register Name | Description            |
|------------|---------------|------------------------|
| 0x9E (SFR) | CRC_REG       | CRC initial register   |
| 0x9F (SFR) | CRC_FIFO      | CRC data fifo register |

### 15.5. 寄存器详细说明

#### 15.5.1. CRC\_REG

Addr = 0x9E (SFR)

| Bit(s) | Name | Description | R/W | Reset |
|--------|------|-------------|-----|-------|
|        |      |             |     |       |

|     |         |                                                                 |   |      |
|-----|---------|-----------------------------------------------------------------|---|------|
| 7:0 | INITSET | CRC 初始值配置<br>每次使用前需要先设置初始值设置 CRC 校验的初始值， 默认上电时 0xffff， 需要写两次初始值 | W | 0xFF |
|-----|---------|-----------------------------------------------------------------|---|------|

### 15.5.2. CRC\_FIFO

Addr = 0x9F (SFR)

| Bit(s) | Name | Description                                                                                  | R/W | Reset |
|--------|------|----------------------------------------------------------------------------------------------|-----|-------|
| 7:0    | DATA | CRC 数据配置<br>写：CRC 每次校验的 1byte 数据<br>读：读 1 次该寄存器就读 1byteCRC 结果，如果需要读 CRC16 的寄过需要读两次进行拼成 16bit | RW  | -     |

## 15.6. 使用流程说明

- 配置CRC\_REG，一般配置为 0xffff/0x0000（需要写两次这个寄存器）
- 把需要校验的 1byte 数据通过CRC\_FIFO这个寄存器写进去
- 需要读取结果时，读取两次CRC\_FIFO拼成一个CRC16 的结果

## 16.FLASH 控制器模块

### 16.1. 功能概述

Logic Flash (以下简称 Flash) 功能特点如下：

- Flash控制器带有操作保护功能（在进行Flash操作前需要配置密码寄存器使能）
- 通过配置寄存器可以实现对Flash存储器进行烧录/扇区（128byte）擦除/全

片 (4K) 擦除的功能，同时支持在线烧录

- 通过配置寄存器可以实现对Flash存储器的数据进行CRC校验
- 支持类EEPROM的使用

## 16.2. 模块框图



图 17-1 FLASH 结构框图

## 16.3. 寄存器列表

表 17-1 FLASH 寄存器列表

| Address    | Register Name | Description                     |
|------------|---------------|---------------------------------|
| 0xA0 (SFR) | FLASH_CON     | FLASH control register          |
| 0xA1 (SFR) | FLASH_STA     | FLASH state register            |
| 0xA2 (SFR) | FLASH_DATA    | FLASH program data register     |
| 0xA3 (SFR) | FLASH_TIM0    | FLASH timing control register 0 |
| 0xA4 (SFR) | FLASH_TIM1    | FLASH timing control register 1 |
| 0xA5 (SFR) | FLASH_CRCLEN  | FLASH CRC data length register  |

|            |                |                                      |
|------------|----------------|--------------------------------------|
| 0xA6 (SFR) | FLASH_PASSWORD | FLASH operation to protect register  |
| 0xA7 (SFR) | FLASH_ADDR     | FLASH program/erase address register |
| 0xAA (SFR) | FLASH_TRIM     | FLASH test mode register             |

## 16.4. 寄存器详细说明

### 16.4.1. FLASH\_CON

Addr = 0xA0 (SFR)

| Bit(s) | Name   | Description                                                                          | R/W | Reset |
|--------|--------|--------------------------------------------------------------------------------------|-----|-------|
| 7:4    | -      | -                                                                                    | -   | -     |
| 3      | CRCST  | FLASH CRC 功能触发<br>写 1 触发 CRC 校验，需要先配置寄器 FLASH_CRCLEN 的大小才可以触发该操作，且不能在 DATA 区跑 CRC 代码 | W0  | 0x0   |
| 2      | CERST  | FLASH 全擦功能触发<br>写 1 触发全片擦除                                                           | W0  | 0x0   |
| 1      | SERST  | FLASH 扇区擦除功能触发<br>写 1 触发扇区擦除，需要配置 128byte 对齐的地址才可以触发                                 | W0  | 0x0   |
| 0      | PROGST | FLASH 烧写功能触发<br>写 1 触发烧录操作                                                           | W0  | 0x0   |

**Note:** FLASH 控制器带有操作保护功能，需要先正确配置 FLASH\_PASSWORD 寄存器才正确触发以上的操作。

### 16.4.2. FLASH\_STA

Addr = 0xA1 (SFR)

| Bit(s) | Name | Description | R/W | Reset |
|--------|------|-------------|-----|-------|
|        |      |             |     |       |

|     |          |                                                                                                |    |     |
|-----|----------|------------------------------------------------------------------------------------------------|----|-----|
| 7:5 | -        | -                                                                                              | -  | -   |
| 4   | NVRLOCK  | FLASH 的 information 区标志信号<br>0x0: information 区没有通过检验（不能正常使用）<br>0x1: information 区通过校验（能正常使用） | RO | 0x1 |
| 3   | CRCPEND  | CRC 模式工作标志位<br>0x0: 正在进行 CRC 校验<br>0x1: 空闲状态                                                   | RO | 0x1 |
| 2   | CERPEND  | 全片擦除模式工作标志<br>0x0: 正在进行全片擦除<br>0x1: 空闲状态                                                       | RO | 0x1 |
| 1   | SERPEND  | 扇区擦除模式工作标志<br>0x0: 正在进行扇区擦除<br>0x1: 空闲状态                                                       | RO | 0x1 |
| 0   | PROGPEND | 烧录模式工作标志<br>0x0: 正在进行烧录<br>0x1: 空闲状态                                                           | RO | 0x1 |

#### 16.4.3. FLASH\_DATA

Addr = 0xA2 (SFR)

| Bit(s) | Name | Description                                                            | R/W | Reset |
|--------|------|------------------------------------------------------------------------|-----|-------|
| 7:0    | DATA | FLASH 烧写数据<br>FLASH 存储器的数据为 16 位，需要操作的时候需要对该寄存器写两次，第一次写低 8 位，第二次写高 8 位 | RW  | 0x0   |

#### 16.4.4. FLASH\_TIM0

Addr = 0xA3 (SFR)

| Bit(s) | Name | Description | R/W | Reset |
|--------|------|-------------|-----|-------|
|        |      |             |     |       |

|     |       |                                                                         |    |     |
|-----|-------|-------------------------------------------------------------------------|----|-----|
| 7:6 | TERH  | 扇区擦除时序控制（默认时间为 50ms）<br>0x0: 默认值<br>0x1: 51ms<br>0x2: 52ms<br>0x3: 53ms | RW | 0x0 |
| 5:4 | TPOAM | 后同步信号时序控制信号（默认时间为 2us）<br>0x0: 默认值<br>0x1: 3us<br>0x2: 4us<br>0x3: 5us  | RW | 0x0 |
| 3:2 | TPRAM | 前同步信号时序控制信号（默认时间为 2us）<br>0x0: 默认值<br>0x1: 3us<br>0x2: 4us<br>0x3: 5us  | RW | 0x0 |
| 1:0 | TPGHF | 烧录时序控制信号（默认时间为 20us）<br>0x0: 默认值<br>0x1: 21us<br>0x2: 22us<br>0x3: 23us | RW | 0x0 |

#### 16.4.5. FLASH\_TIM1

Addr = 0xA4 (SFR)

| Bit(s) | Name  | Description                                                                     | R/W | Reset |
|--------|-------|---------------------------------------------------------------------------------|-----|-------|
| 7:6    | TPEL  | 连续操作时序控制（默认时间为 2*Tsys）<br>0x0: 默认值<br>0x1: 3*Tsys<br>0x2: 4*Tsys<br>0x3: 5*Tsys | RW  | 0x0   |
| 5:4    | TCERH | 全片擦除时序控制信号（默认时间为 50ms）<br>0x0: 默认值                                              | RW  | 0x0   |

|     |     |                                                                     |    |     |
|-----|-----|---------------------------------------------------------------------|----|-----|
|     |     | 0x1: 51ms<br>0x2: 52ms<br>0x3: 53ms                                 |    |     |
| 3:2 | TKP | 读周期时序控制信号<br>0x0: 默认值<br>0x1: Tsys<br>0x2: 2*Tsys<br>0x3: 3*Tsys    | RW | 0x0 |
| 1:0 | TKH | 读信号高电平时序控制信号<br>0x0: 默认值<br>0x1: Tsys<br>0x2: 2*Tsys<br>0x3: 3*Tsys | RW | 0x0 |

**Note:** TKH 应配置大于等于 TKP 的值 (TKP 和 TKH 的配置请查看具体的配置表)

#### 16.4.6. FLASH\_CRCLEN

Addr = 0xA5 (SFR)

| Bit(s) | Name | Description                           | R/W | Reset |
|--------|------|---------------------------------------|-----|-------|
| 7:0    | LEN  | CRC 操作的数据长度<br>CRC 校验操作的数据大小 (单位: 字节) | RW  | 0x0   |

**Note:** 当 FLASH\_CRCLEN 的配置值为 0 时，CRC 操作无法触发！

#### 16.4.7. FLASH\_PSWD

Addr = 0xA6 (SFR)

| Bit(s) | Name     | Description                                                    | R/W | Reset |
|--------|----------|----------------------------------------------------------------|-----|-------|
| 7:0    | PASSWORD | FLASH 操作保护的密码寄存器<br>操作保护密码，执行 FLASH_CON 的操作之前需要配置该寄存器，密码为 0xB9 | WO  | 0x0   |

#### 16.4.8. FLASH\_ADDR

Addr = 0xA7 (SFR)

| Bit(s) | Name | Description                                                                     | R/W | Reset |
|--------|------|---------------------------------------------------------------------------------|-----|-------|
| 7:0    | ADDR | <b>FLASH 的地址寄存器</b><br>FLASH 存储器的地址为 12 位，需要操作的时候需要对该寄存器写两次，第一次写高 4 位，第二次写低 8 位 | W0  | 0x0   |

**Note:** 进行 FLASH 的烧录/扇区擦除/全片擦除时，需要将地址对齐，否则无法进行操作

#### 16.4.9. FLASH\_TRIM

Addr = 0xAA (SFR)

| Bit(s) | Name     | Description        | R/W | Reset |
|--------|----------|--------------------|-----|-------|
| 7:6    | -        | -                  | -   | -     |
| 5      | MODESEL  | 测试模式下的 MODESEL 信号  | RW  | 0x0   |
| 4:3    | TRIM     | 测试模式下的 TRIM 信号     | RW  | 0x2   |
| 2:1    | VRDCGSEL | 测试模式下的 VRDCGSEL 信号 | RW  | 0x1   |
| 0      | TRF      | 测试模式下的 TRF 信号      | RW  | 0x0   |

**Note:** 正常使用下不用配置这个寄存器（只供测试使用，在非测试模式下使用可能会引发问题）

### 16.5. 使用流程说明

- 配置需要操作的FLASH的地址（需对齐对应的地址才可以触发对应的操作）
- 配置需要操作的FLASH的数据

- 配置FLASH\_PASSWORD寄存器使能
- 配置FLASH\_CON触发对应的FLASH操作
- 等FLASH\_STA对应的pending为高，结束一次FLASH操作

## 17. 模数转换器(ADC)

### 17.1. 功能概述

该模块是一个12bit的逐次逼近式的ADC控制器。ADC支持多种工作模式：单次转换/两通道交替触发，可以选择所有的GPIO和内部通道进行转换，ADC的启动包括软件启动、以及高级Timer1/2触发启动。

ADC 的输入时钟不得超过 4Mhz 是由系统时钟经分频产生。

- ADC具有 12BIT量化，可选内部参考电压或外部参考电压作为ADC的参考电压，内部参考电压为 1.2V和 2.4V可选；外部参考电压默认为VCC
- 可以通过ADC的通路选择把Analog测试信号，输入到任意I/O口
- 转换速度可达 200Ksps
- 采样时间可调，可调范围：5~256 个ADC时钟
- 支持单通道配置延迟触发
- 比较器offset可以使用模拟/数字校准
- 支持双通道带仲裁触发（两个通道都不开启硬件延迟功能）
- 支持 1 路软件触发和 7 路硬件触发
- 支持所有GPIO和内部通道作为模拟转换通道

## 17.2. 基本功能

### 17.2.1. 单通道触发模式

单通道触发模式是只使能 ADC\_CFG0 中的 CHANOEN/CHAN1EN，如果只使能通道 0 时，只有配置的 ADC\_CHS0 的通道 0 的触发源可以触发 ADC 的转换，而且此时 ADC 使用的是 ADC\_CHS0 的模拟转换通道，当然，只使能通道 1 同理。

### 17.2.2. 双通道触发模式

双通道触发模式是同时使能 ADC\_CFG0 中 CHANOEN/CHAN1EN，在这种模式下，通道 0 的优先级高于通道 1 的优先级，在这种时候一般会出现以下两种情况：

- 仲裁：当 ADC\_CHS0 和 ADC\_CHS1 中的配置的触发源在同一时刻触发 ADC 时，会先响应 ADC\_CHS0 的配置的触发源，同时采用 ADC\_CHS0 中对应的模拟采样通道，再响应完后通道 0 的触发后才响应通道 1 的触发，响应通道 1 的触发时使用 ADC\_CHS1 中对应的模拟采样通道
- 排队：在通道 0 进行转换时，此时如果再来通道 0 的触发将会忽视，不会响应也不会进行锁存，如果此时来通道 1 的触发将会锁存通道 1 的请求，等到通道 0 转换完之后再进行通道 1 的转换，当然，在通道 1 进行转换时也是同理，来通道 1 的触发将会忽视，但是如果此时来通道 0 的触发，会锁存对应的请求，等到通道 1 转换完成后才会去转换通道 0。

### 17.2.3. 单通道触发延迟模式

单通道触发延迟模式是只使能 ADC\_CFG0 中的 CHANOEN&DLY0EN/CHAN1EN&DLY1EN，在这种模式下当通道 0 在 ADC\_CHS0 配置的触发源来了之后，并不是马上开始 ADC 转换，需要等

待 ADC\_CFG3 中配置的延迟时间后才会去进行 ADC 转换，与此同时，在这种模式下，ADC 的两个通道没有仲裁机制，所以在这种模式下建议不要使能另一个通道进行转换。

#### 17.2.4. 模拟校准/数字校准

模拟校准需要先使能 ADC\_CFG0 中 CALIBEN，然后将通道 0 配置成单通道触发模式，进行一次软件触发后，将转换后的结果的低 6 位写到 comp\_trim\_vdd，然后再关闭 CALIBEN，并且清楚 ADC\_STA 中通道 0 完成标志和模拟校准标志，完成模拟校准。

数字校准只需要 ADC\_CFG1 的 CPCALIBST，等待 ADC\_STA 中的数字校准标志位后，清除数字校准标志位后完成数字校准。

### 17.3. 模块框图



图 17-1 ADC 结构框图

### 17.4. 寄存器列表

表 17-1 ADC 寄存器列表

| Address    | Register Name | Description                  |
|------------|---------------|------------------------------|
| 0x91 (SFR) | ADC_CFG0      | ADC configuration 0 register |
| 0x92 (SFR) | ADC_CFG1      | ADC configuration 1 register |
| 0x9A (SFR) | ADC_CFG2      | ADC configuration 2 register |
| 0xEE (SFR) | ADC_CFG3      | ADC configuration 3 register |
| 0x93 (SFR) | ADC_STA       | ADC state register           |

|            |            |                                      |
|------------|------------|--------------------------------------|
| 0x94 (SFR) | ADC_DATAH0 | ADC channel0 data high 8bit register |
| 0x95 (SFR) | ADC_DATAL0 | ADC channel0 data low 4bit register  |
| 0x96 (SFR) | ADC_DATAH1 | ADC channel1 data high 8bit register |
| 0x97 (SFR) | ADC_DATAL1 | ADC channel1 data low 4bit register  |
| 0x98 (SFR) | ADC_CHS0   | ADC channel0 select register         |
| 0x99 (SFR) | ADC_CHS1   | ADC channel1 select register         |

## 17.5. 寄存器详细说明

### 17.5.1. ADC\_CFG0

Addr = 0x91 (SFR)

| Bit(s) | Name    | Description                                    | R/W | Reset |
|--------|---------|------------------------------------------------|-----|-------|
| 7      | CALIBEN | 开启硬件校准<br>开启后的通道 0 作为校准结果，填回去<br>comp_trim_vdd | RW  | 0x0   |
| 6      | DLY1EN  | 通道 1 ADC 触发延迟功能使能<br>0x0: 关闭<br>0x1: 打开        | RW  | 0x0   |
| 5      | DLYOEN  | 通道 0 ADC 触发延迟功能使能<br>0x0: 关闭<br>0x1: 打开        | RW  | 0x0   |
| 4      | ADCEN   | A/D 转换使能<br>0x0: 关闭<br>0x1: 打开                 | RW  | 0x0   |
| 3      | CHAN1EN | 通道 1 转换使能<br>0x0: 关闭<br>0x1: 打开                | RW  | 0x0   |
| 2      | CHANOEN | 通道 0 转换使能<br>0x0: 关闭                           | RW  | 0x0   |

|   |       |                                           |    |     |
|---|-------|-------------------------------------------|----|-----|
|   |       | 0x1: 打开                                   |    |     |
| 1 | ADST1 | <b>ADC 通道 1 触发转换</b><br>写 1 开始触发通道 1 进行转换 | WO | 0x0 |
| 0 | ADST0 | <b>ADC 通道 0 触发转换</b><br>写 1 开始触发通道 0 进行转换 | WO | 0x0 |

**Note:** 触发延迟功能没有带仲裁功能，所以在使用触发延迟功能的时候不能同时使用两个通道进行转换！

### 17.5.2. ADC\_CFG1

Addr = 0x92 (SFR)

| Bit(s) | Name      | Description                                                                                                                                                                                                                        | R/W | Reset |
|--------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7      | -         | -                                                                                                                                                                                                                                  | -   | -     |
| 6      | CPCALIBST | <b>数字校准功能触发位</b><br>数字校准功能触发，写 1 触发，触发后会 ADC 模块会进行自动校准，校准完后将校准值填到 comp_trim_vdd                                                                                                                                                    | WO  | 0x0   |
| 5:2    | ADCPRE    | <b>ADC 时钟分频</b><br>分频比为 n+1, 0 的时候默认为 2 分频，ADC 最大输入时钟频率为 4MHz, $F_{adc} = F_{sys}/ADCPRE$ , 其中 Fadc 是 ADC 输入频率, Fsys 是系统时钟主频<br>0x0: 2 分频<br>0x1: 2 分频<br>0x2: 3 分频<br>0x3: 4 分频<br>0x4: 5 分频<br>.....<br>0xE: 15 分频<br>0xF: 16 分频 | RW  | 0x7   |
| 1      | CHAN1IE   | <b>ADC 通道 1 的中断使能</b><br>0x0: 关闭<br>0x1: 打开                                                                                                                                                                                        | RW  | 0x0   |

|   |         |                                      |    |     |
|---|---------|--------------------------------------|----|-----|
| 0 | CHANOIE | ADC 通道 0 的中断使能<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
|---|---------|--------------------------------------|----|-----|

### 17.5.3. ADC\_CFG2

Addr = 0x9A (SFR)

| Bit(s) | Name    | Description                                                                                                   | R/W | Reset |
|--------|---------|---------------------------------------------------------------------------------------------------------------|-----|-------|
| 7:0    | FSMPCYC | 采样时间配置<br>配置比为 n+1 时钟<br>0x0: 1 个 ADC 时钟<br>0x1: 2 个 ADC 时钟<br>0x2: 3 个 ADC 时钟<br>.....<br>0xFF: 256 个 ADC 时钟 | RW  | 0x4   |

Note: 为了 ADC 能够正常工作, 采样时间最少配置为 0x3

### 17.5.4. ADC\_CFG3

Addr = 0xEE (SFR)

| Bit(s) | Name   | Description                                                                                                           | R/W | Reset |
|--------|--------|-----------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7:4    | -      | -                                                                                                                     | -   | -     |
| 3:0    | DLYCYC | 触发延迟时间配置<br>配置比为 4n+3 个 ADC 时钟<br>0x0: 3 个 ADC 时钟<br>0x1: 7 个 ADC 时钟<br>0x2: 11 个 ADC 时钟<br>.....<br>0xF: 67 个 ADC 时钟 | RW  | 0x0   |

### 17.5.5. ADC\_STA

Addr = 0x93 (SFR)

| Bit(s) | Name        | Description                                                                  | R/W | Reset |
|--------|-------------|------------------------------------------------------------------------------|-----|-------|
| 7:5    | -           | -                                                                            | -   | -     |
| 4      | EODTADCFLAG | <b>数数字校准完成标志</b><br>0x0: 数字校准没有完成/没有使能<br>0x1: 数字校准完成<br>写 1 清 0             | RW  | 0x0   |
| 3      | EOATADCFLAG | <b>模拟校准完成标志</b><br>0x0: 模拟校准没有完成/没有使能<br>0x1: 模拟校准完成<br>写 1 清 0              | RW  | 0x0   |
| 2      | CHAN10VPEND | <b>通道 1 转换完成标志</b><br>0x0: 通道 1 转换没有完成/没有使能通道 1<br>0x1: 通道 1 转换完成<br>写 1 清 0 | RW  | 0x0   |
| 1      | CHAN00VPEND | <b>通道 0 转换完成标志</b><br>0x0: 通道 0 转换没有完成/没有使能通道 1<br>0x1: 通道 0 转换完成<br>写 1 清 0 | RW  | 0x0   |
| 0      | BUSY        | <b>ADC 忙/空闲标志</b><br>0x0: ADC 空闲<br>0x1: ADC 转换中                             | RO  | 0x0   |

### 17.5.6. ADC\_DATAH0

Addr = 0x94 (SFR)

| Bit(s) | Name   | Description               | R/W | Reset |
|--------|--------|---------------------------|-----|-------|
| 7:0    | DATAOH | 通道 0 的 12 位 A/D 转换结果高 8 位 | RW  | 0x0   |

### 17.5.7. ADC\_DATA0

Addr = 0x95 (SFR)

| Bit(s) | Name   | Description               | R/W | Reset |
|--------|--------|---------------------------|-----|-------|
| 7:4    | -      | -                         | -   | -     |
| 3:0    | DATA0L | 通道 0 的 12 位 A/D 转换结果低 4 位 | RW  | 0x0   |

### 17.5.8. ADC\_DATAH1

Addr = 0x96 (SFR)

| Bit(s) | Name   | Description               | R/W | Reset |
|--------|--------|---------------------------|-----|-------|
| 7:0    | DATA1H | 通道 1 的 12 位 A/D 转换结果高 8 位 | RW  | 0x0   |

### 17.5.9. ADC\_DATA1L

Addr = 0x97 (SFR)

| Bit(s) | Name   | Description               | R/W | Reset |
|--------|--------|---------------------------|-----|-------|
| 7:4    | -      | -                         | -   | -     |
| 3:0    | DATA1L | 通道 1 的 12 位 A/D 转换结果低 4 位 | RW  | 0x0   |

### 17.5.10. ADC\_CHS0

Addr = 0x98 (SFR)

| Bit(s) | Name    | Description                                                  | R/W | Reset |
|--------|---------|--------------------------------------------------------------|-----|-------|
| 7:5    | TRGSELO | 硬件触发源选择<br>0x0: 选择软件触发<br>0x1: Timer0ov<br>0x2: 高级 Timer1 中断 | RW  | 0x0   |

|     |          |                                                                                                                                                                                                                                                                                                                                                        |    |      |
|-----|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|------|
|     |          | 0x3: 高级 Timer2 中断<br>0x4: 高级 Timer1 CMPA_ACK<br>0x5: 高级 Timer1 CMPB_ACK<br>0x6: 高级 Timer2 CMPA_ACK<br>0x7: 高级 Timer2 CMPB_ACK                                                                                                                                                                                                                          |    |      |
| 4:0 | CHANSEL0 | <b>通道 0 的模拟转换通道选择</b><br>0x0~0x7 分别选择 P00~P07 通路,<br>0x8~0xD 分别选择 P10~P15 通路:<br>0x0: P00<br>0x1: P01<br>0x2: P02<br>0x3: P03<br>0x4: P04<br>0x5: P05<br>0x6: P06<br>0x7: P07<br>0x8: reserved<br>0x9: P11<br>0xA: P12<br>0xB: P13<br>0xC: P14<br>0xD: P15<br>0xE: PTAT<br>0xF: VBG06_ADC<br>0x10: VCCA 的 5 分压值<br>0x11: analog test out<br>其他码均不选择/保留 | RW | 0x1F |

### 17.5.11. ADC\_CHS1

Addr = 0x99 (SFR)

| Bit(s) | Name | Description | R/W | Reset |
|--------|------|-------------|-----|-------|
|        |      |             |     |       |

|     |          |                                                                                                                                                                                                                                                                                                                                                        |    |      |
|-----|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|------|
|     |          | <b>硬件触发源选择</b><br>0x0: 选择软件触发<br>0x1: Timer0ov<br>0x2: 高级 Timer1 中断<br>0x3: 高级 Timer2 中断<br>0x4: 高级 Timer1 CMPA_ACK<br>0x5: 高级 Timer1 CMPB_ACK<br>0x6: 高级 Timer2 CMPA_ACK<br>0x7: 高级 Timer2 CMPB_ACK                                                                                                                                                   | RW | 0x0  |
| 4:0 | CHANSEL1 | <b>通道 1 的模拟转换通道选择</b><br>0x0~0x7 分别选择 P00~P07 通路,<br>0x8~0xD 分别选择 P10~P15 通路:<br>0x0: P00<br>0x1: P01<br>0x2: P02<br>0x3: P03<br>0x4: P04<br>0x5: P05<br>0x6: P06<br>0x7: P07<br>0x8: reserved<br>0x9: P11<br>0xA: P12<br>0xB: P13<br>0xC: P14<br>0xD: P15<br>0xE: PTAT<br>0xF: VBG06_ADC<br>0x10: VCCA 的 5 分压值<br>0x11: analog test out<br>其他码均不选择/保留 | RW | 0x1F |

## 17.6. 使用流程说明

- 配置ADC\_CFG1 的ADCPRE，设定ADC时钟分频
- 配置ADC\_CFG0 使能通道转换
- 配置ADC\_CFG2 配置采样时间
- 配置ADC\_CHS0/ADC\_CHS1 配置模拟转换通道和触发源
- 配置ADC\_CFG0 使能ADC
- 等待 20us (等待期间不能触发ADC转换) 触发ADC
- 等待ADC\_STA中对应的通道的pending为
- ADC\_DATAH0/ADC\_DATAH1 的转换结果

## 18. 模拟比较器 (CMP0/1)

### 18.1. 功能概述

比较器功能特点如下：

- DACMP 主要包括 2 个 8 bit flash DAC, 2 个比较器, 1 路 20mA 恒流源输出
- 每个比较器正端可选择 2 路端口 (AIO) 输入和 1 路 PGA 输入, 负端可选择 2 路端口(AIO)输入和 DAC 输入, 其中比较器 0 正端还支持阈值短路 (VCCA-VTH 或 PAD-VTH) 保护输入, 比较器 1 支持 CCS 采样电压输入
- DAC 的参考电压可选择内部 1.2V 参考, 输出为  $1.2/240^*(1^{\sim}240)$
- 内置 2 路阈值短路保护 (可选 VCCA-VTH 或者 PAD-VTH), 其中 VTH 档位调节输出电压可选为 80mv/200mv/320mv/480mv
- 1 路 6bit 校准精度为 2.5% 的 20mA 恒流源输出, TYP 输出范围:  $-40.5^{\sim}+42\%$
- 均可支持 P 输入对管或者 N 输入对端输入, 支持 P 输入管的 offset 电压校准, 校准 step 在 typ 下为 2mv, 校准范围为  $-13mv^{\sim}+13mv$
- 支持数字滤波, 滤波时间共 32 档位选择, 步长为 1 微秒

- 支持数字迟滞控制，迟滞采样间隔 16 个档位可选，步长 1 微秒和 16 微秒可选
- 数字迟滞电压可在  $1.2/240 \times (1 \sim 240)$  内选择
- 支持失调电压软件修调
- 输出可作为增强型 PWM 的刹车触发信号
- 支持输出改变产生中断
- 支持比较器唤醒睡眠状态
- 比较器使能可由内部 PWM 控制

## 18.2. 模块框图



图 19-1 比较器 0 模拟的内部框图



图 19-2 比较器 1 模拟的内部框图

### 18.3. 引脚对应表

表 19-1 CMP 寄存器列表

| 输入端  |           | CMPx_CON1<br>[CHPSEL] | CMPx_CON1<br>[CHNSEL] | GPIO |
|------|-----------|-----------------------|-----------------------|------|
| CMPO | CMP0_N[0] | /                     | 0x01                  | P02  |
|      | CMP0_N[1] | /                     | 0x02                  | P14  |
|      | CMP0_P[0] | 0x01                  | /                     | P11  |
|      | CMP0_P[1] | 0x02                  | /                     | P12  |
| CMP1 | CMP1_N[0] | /                     | 0x01                  | P00  |
|      | CMP1_N[1] | /                     | 0x02                  | P01  |
|      | CMP1_P[0] | 0x01                  | /                     | P03  |
|      | CMP1_P[1] | 0x02                  | /                     | P13  |

Note: 表格中 CMPx\_CON1 是指 CMPO\_CON1 和 CMP1\_CON1

## 18.4. 寄存器列表

表 19-2 CMP 寄存器列表

| Address     | Register Name | Description                       |
|-------------|---------------|-----------------------------------|
| 0x36 (XSFR) | CMP0_CON0     | CMP0 configuration 0 register     |
| 0x37 (XSFR) | CMP0_CON1     | CMP0 configuration 1 register     |
| 0x38 (XSFR) | CMP1_CON0     | CMP1 configuration 0 register     |
| 0x39 (XSFR) | CMP1_CON1     | CMP1 configuration 1 register     |
| 0x3A (XSFR) | CMP_CON       | CMP configuration common register |
| 0x3B (XSFR) | CMP_STA       | CMP status register               |
| 0x74 (XSFR) | CMP0_CON2     | CMP0 configuration 2 register     |
| 0x75 (XSFR) | CMP0_CON3     | CMP0 configuration 3 register     |
| 0x76 (XSFR) | CMP0_CON4     | CMP0 configuration 4 register     |
| 0x77 (XSFR) | CMP0_DAC0     | DAC0 register of CMP0             |
| 0x78 (XSFR) | CMP0_DAC1     | DAC1 register of CMP0             |
| 0x79 (XSFR) | CMP1_CON2     | CMP1 configuration 2 register     |
| 0x7A (XSFR) | CMP1_CON3     | CMP1 configuration 3 register     |
| 0x7b (XSFR) | CMP1_CON4     | CMP1 configuration 4 register     |
| 0x7C (XSFR) | CMP1_DAC0     | DAC0 register of CMP1             |
| 0x7D (XSFR) | CMP1_DAC1     | DAC1 register of CMP1             |

## 18.5. 寄存器详细说明

### 18.5.1. CMP0\_CON0

Addr = 0x36 (XSFR)

| Bit(s) | Name    | Description                                                                      | R/W | Reset |
|--------|---------|----------------------------------------------------------------------------------|-----|-------|
| 7:5    | CMPINTS | 比较器输出结果产生中断触发方式控制寄存器<br>0x0: 上升沿<br>0x1: 下降沿<br>0x2: 双边沿<br>0x3: 高电平<br>0x4: 低电平 | RW  | 0x0   |
| 4      | -       | -                                                                                | -   | -     |
| 3      | INVENA  | 比较器结果取反使能<br>0x0: 比较器结果不取反<br>0x1: 比较器结果取反                                       | RW  | 0x0   |
| 2      | CMPOUT  | 比较器的比较结果                                                                         | RO  | 0x0   |
| 1      | INTENA  | 中断使能信号<br>0x0: 关闭<br>0x1: 打开                                                     | RW  | 0x0   |
| 0      | ENA     | 比较器的模拟部分使能<br>使能之后还需要使能数字部分，比较器才正常工作<br>0x0: 关闭<br>0x1: 打开                       | RW  | 0x0   |

### 18.5.2. CMP0\_CON1

Addr = 0x37 (XSFR)

| Bit(s) | Name     | Description                                    | R/W | Reset |
|--------|----------|------------------------------------------------|-----|-------|
| 7      | VTHVCCEN | VCC 短路保护阈值输入使能信号<br>(VCC - 0.08/0.2/0.32/0.48) | RW  | 0x0   |

|     |          |                                                                                                              |    |     |
|-----|----------|--------------------------------------------------------------------------------------------------------------|----|-----|
|     |          | 0x0: 关闭<br>0x1: 打开                                                                                           |    |     |
| 6   | VTHPADEN | PAD 短路保护阈值输入使能信号<br>(PAD = 0.08/0.2/0.32/0.48)<br>0x0: 关闭<br>0x1: 打开                                         | RW | 0x0 |
| 5:4 | CMPVTHS  | 比较器内置阈值选择<br>0x0: VCC (PAD) -80mv<br>0x1: VCC (PAD) -200mv<br>0x2: VCC (PAD) -320mv<br>0x3: VCC (PAD) -480mv | RW | 0x0 |
| 3:2 | CHPSEL   | 比较器正端输入通道选择<br>0x0: 关闭<br>0x1: CMPO_P<0> -> P11<br>0x2: CMPO_P<1> -> P12<br>0x3: VTH_OUT_VCC/VTH_OUT_PAD     | RW | 0x0 |
| 1:0 | CHNSEL   | 比较器负端输入通道选择<br>0x0: 关闭<br>0x1: CMPO_N<0> -> P02<br>0x2: CMPO_N<1> -> P14<br>0x3: DACO_OUT                    | RW | 0x0 |

### 18.5.3. CMPO\_CON2

Addr = 0x74 (XSFR)

| Bit(s) | Name     | Description                                                               | R/W | Reset |
|--------|----------|---------------------------------------------------------------------------|-----|-------|
| 7:6    | CMPFSEL  | 比较器结果选择位<br>0x0: 比较器输出数字滤波器滤波后的结果<br>0x1: 比较器输出同步后的结果<br>0x2: 比较器输出迟滞采样结果 | RW  | 0x0   |
| 5      | OUTPUTEN | 控制比较器结果是否输出控制位<br>0x0: 不输出, 结果保持关闭输出前的值<br>0x1: 输出                        | RW  | 0x0   |

|     |         |                                                                                                                      |    |     |
|-----|---------|----------------------------------------------------------------------------------------------------------------------|----|-----|
| 4:0 | FILTNUM | <b>滤波时钟个数设置</b><br>最大值 32, 步长为 1 微秒, 即滤波时钟频率是 1M<br>0x00: 滤波 1 个时钟周期<br>0x01: 滤波 2 个时钟周期<br>...<br>0x1F: 滤波 32 个时钟周期 | RW | 0x0 |
|-----|---------|----------------------------------------------------------------------------------------------------------------------|----|-----|

#### 18.5.4. CMP0\_CON3

Addr = 0x75 (XSFR)

| Bit(s) | Name         | Description                                                                                                                   | R/W | Reset |
|--------|--------------|-------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7      | HYSEL        | <b>选择迟滞信号是否经过滤波器</b><br>0x0: 经过滤波后的信号<br>0x1: 滤波前的同步信号                                                                        | RW  | 0x0   |
| 6      | HYSEN        | <b>比较器数字迟滞功能使能位</b><br>通过 DAC 的两个寄存器控制阈值<br>0x0: 关闭迟滞<br>0x1: 打开迟滞                                                            | RW  | 0x0   |
| 5      | CMPENS       | <b>比较器输出控制选择</b><br>0x0: 比较器是否输出由 OUTPUT_EN 决定<br>0x1: 比较器是否输出由 PWM 控制                                                        | RW  | 0x0   |
| 4      | HYSRCSEL     | <b>迟滞计数源选择</b><br>0x0: 1M 时钟<br>0x1: 64K 时钟                                                                                   | RW  | 0x0   |
| 3:0    | CMP0COUNTREG | <b>迟滞计数器, 用来设置迟滞采样间隔</b><br>步长为 16 微秒(64K 时钟)和 1 微秒(1M 时钟)可选<br>0x0: 间隔 1 个周期采样<br>0x1: 间隔 2 个周期采样<br>...<br>0xF: 间隔 16 个周期采样 | RW  | 0x0   |

### 18.5.5. CMP0\_CON4

Addr = 0x76 (XSFR)

| Bit(s) | Name       | Description                                            | R/W | Reset |
|--------|------------|--------------------------------------------------------|-----|-------|
| 7      | DACTSEN[0] | 比较器 0 的 DAC 的输出测试使能信号<br>0x0: 关闭<br>0x1: 打开            | RW  | 0x0   |
| 6      | P_DISABLE  | 关闭 P 管<br>0x0: 不关闭 P 管<br>0x1: 关闭 P 管                  | RW  | 0x1   |
| 5      | OSSHORT    | 短路使能<br>短接比较器正负端, 用于比较器校准<br>0x0: 不短接正负端<br>0x1: 短接正负端 | RW  | 0x0   |
| 4      | N_DISABLE  | 关闭 N 管<br>0x0: 不关闭 N 管<br>0x1: 关闭 N 管                  | RW  | 0x0   |
| 3:0    | TRIM       | 比较器 0 校正值<br>芯片上电会自动填入出厂校验值, 也可用户填入校验值                 | RW  | -     |

注意: 共模电压 (比较器两端的电压) 比较低 (低于 1/2VDD) 时应关闭 N 管打开 P 管, 共模电压比较高时应关闭 P 管打开 N 管, 如果电压在 0~VCC 之间, 需两个同时打开。注意: CMPO 默认只打开 P 管, CMP1 默认只打开 N 管。

### 18.5.6. CMP0\_DAC0

Addr = 0x77 (XSFR)

| Bit(s) | Name      | Description                                                                                                                                            | R/W | Reset |
|--------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7:0    | CMP0_DAC0 | 比较器 0 的 DAC0 寄存器<br>如果不开启数字迟滞, 本寄存器即为比较器 0 内置 DAC 的输入, 如果开启数字迟滞, DAC 的输入值在 CMP0_DAC0 和 CMP0_DAC1 之间选择, 当比较输出为 1 时选择 CMP0_DAC0, 当比较器输出为 0 时选择 CMP0_DAC1 | RW  | 0x0   |

|  |  |                                                             |  |  |
|--|--|-------------------------------------------------------------|--|--|
|  |  | Step=5mV, 0x00~0xF0 对应转换输出为 0~1.2V,<br>0xF0~0xFF 转换输出为 1.2V |  |  |
|--|--|-------------------------------------------------------------|--|--|

### 18.5.7. CMP0\_DAC1

Addr = 0x78 (XSFR)

| Bit(s) | Name      | Description                                                                                  | R/W | Reset |
|--------|-----------|----------------------------------------------------------------------------------------------|-----|-------|
| 7:0    | CMP0_DAC1 | 比较器 0 的 DAC1 寄存器<br>使能数字迟滞时生效<br>Step=5mV, 0x00~0xF0 对应转换输出为 0~1.2V,<br>0xF0~0xFF 转换输出为 1.2V | RW  | 0x0   |

### 18.5.8. CMP1\_CON0

Addr = 0x38 (XSFR)

| Bit(s) | Name    | Description                                                                      | R/W | Reset |
|--------|---------|----------------------------------------------------------------------------------|-----|-------|
| 7:5    | CMPINTS | 比较器输出结果产生中断触发方式控制寄存器<br>0x0: 上升沿<br>0x1: 下降沿<br>0x2: 双边沿<br>0x3: 高电平<br>0x4: 低电平 | RW  | 0x0   |
| 4      | -       | -                                                                                | -   | -     |
| 3      | INVENA  | 比较器结果取反使能<br>0x0: 比较器结果不取反<br>0x1: 比较器结果取反                                       | RW  | 0x0   |
| 2      | CMPOUT  | 比较器的比较结果                                                                         | RO  | 0x0   |
| 1      | INTENA  | 中断使能信号<br>0x0: 关闭<br>0x1: 打开                                                     | RW  | 0x0   |
| 0      | ENA     | 比较器的模拟部分使能<br>使能之后还需要使能数字部分，比较器才正常工                                              | RW  | 0x0   |

|  |  |                         |  |  |
|--|--|-------------------------|--|--|
|  |  | 作<br>0x0: 关闭<br>0x1: 打开 |  |  |
|--|--|-------------------------|--|--|

### 18.5.9. CMP1\_CON1

Addr = 0x39 (XSFR)

| Bit(s) | Name   | Description                                                                               | R/W | Reset |
|--------|--------|-------------------------------------------------------------------------------------------|-----|-------|
| 7:4    | -      | -                                                                                         | -   | -     |
| 3:2    | CHPSEL | 比较器正端输入通道选择<br>0x0: 关闭<br>0x1: CMP1_P<0> -> P03<br>0x2: CMP1_P<1> -> P13<br>0x3: CCS_FB   | RW  | 0x0   |
| 1:0    | CHNSEL | 比较器负端输入通道选择<br>0x0: 关闭<br>0x1: CMP1_N<0> -> P00<br>0x2: CMP1_N<1> -> P01<br>0x3: DAC0_OUT | RW  | 0x0   |

### 18.5.10. CMP1\_CON2

Addr = 0x79 (XSFR)

| Bit(s) | Name     | Description                                                               | R/W | Reset |
|--------|----------|---------------------------------------------------------------------------|-----|-------|
| 7:6    | CMPFSEL  | 比较器结果选择位<br>0x0: 比较器输出数字滤波器滤波后的结果<br>0x1: 比较器输出同步后的结果<br>0x2: 比较器输出迟滞采样结果 | RW  | 0x0   |
| 5      | OUTPUTEN | 控制比较器结果是否输出控制位<br>0x0: 不输出, 结果保持关闭输出前的值<br>0x1: 输出                        | RW  | 0x0   |
| 4:0    | FILTNUM  | 滤波时钟个数设置                                                                  | RW  | 0x0   |

|  |  |                                                                                                   |  |  |
|--|--|---------------------------------------------------------------------------------------------------|--|--|
|  |  | 最大值 32, 步长为 1 微秒, 即滤波时钟频率是 1M<br>0x00: 滤波 1 个时钟周期<br>0x01: 滤波 2 个时钟周期<br>...<br>0x1F: 滤波 32 个时钟周期 |  |  |
|--|--|---------------------------------------------------------------------------------------------------|--|--|

### 18.5.11. CMP1\_CON3

Addr = 0x7A (XSFR)

| Bit(s) | Name         | Description                                                                                                            | R/W | Reset |
|--------|--------------|------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7      | HYSEL        | 选择迟滞信号是否经过滤波器<br>0x0: 经过滤波后的信号<br>0x1: 滤波前的同步信号                                                                        | RW  | 0x0   |
| 6      | HYSEN        | 比较器数字迟滞功能使能位<br>通过 DAC 的两个寄存器控制阈值<br>0x0: 关闭迟滞<br>0x1: 打开迟滞                                                            | RW  | 0x0   |
| 5      | CMPENS       | 比较器输出控制选择<br>0x0: 比较器是否输出由 OUTPUT_EN 决定<br>0x1: 比较器是否输出由 PWM 控制                                                        | RW  | 0x0   |
| 4      | HYSRCSEL     | 迟滞计数源选择<br>0x0: 1M 时钟<br>0x1: 64K 时钟                                                                                   | RW  | 0x0   |
| 3:0    | CMPOCOUNTREG | 迟滞计数器<br>用来设置迟滞采样间隔, 步长为 16 微秒(64K 时钟)和 1 微秒(1M 时钟)可选<br>0x0: 间隔 1 个周期采样<br>0x1: 间隔 2 个周期采样<br>...<br>0xF: 间隔 16 个周期采样 | RW  | 0x0   |

### 18.5.12. CMP1\_CON4

Addr = 0x7B (XSFR)

| Bit(s) | Name       | Description                                            | R/W | Reset |
|--------|------------|--------------------------------------------------------|-----|-------|
| 7      | DACTSEN[1] | 比较器 1 的 DAC 的输出测试使能信号<br>0x0: 关闭<br>0x1: 打开            | RW  | 0x0   |
| 6      | P_DISABLE  | 关闭 P 管<br>0x0: 不关闭 P 管<br>0x1: 关闭 P 管                  | RW  | 0x0   |
| 5      | OSSHORT    | 短路使能<br>短接比较器正负端, 用于比较器校准<br>0x0: 不短接正负端<br>0x1: 短接正负端 | RW  | 0x0   |
| 4      | N_DISABLE  | 关闭 N 管<br>0x0: 不关闭 N 管<br>0x1: 关闭 N 管                  | RW  | 0x1   |
| 3:0    | TRIM       | 比较器 0 校正值<br>芯片上电会自动填入出厂校验值, 也可用户填入校验值                 | RW  | -     |

注意: 共模电压 (比较器两端的电压) 比较低 (低于 1/2VDD) 时应关闭 N 管打开 P 管, 共模电压比较高时应关闭 P 管打开 N 管, 如果电压在 0~VCC 之间, 需两个同时打开。注意: CMPO 默认只打开 P 管, CMP1 默认只打开 N 管。

### 18.5.13. CMP1\_DAC0

Addr = 0x7C (XSFR)

| Bit(s) | Name      | Description                                                                                                                              | R/W | Reset |
|--------|-----------|------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7:0    | CMPO_DAC0 | 比较器 0 的 DAC0 寄存器<br>如果不开启数字迟滞, 本寄存器即为比较器 1 内置 DAC 的输入, 如果开启数字迟滞, DAC 的输入值在 CMP1_DAC0 和 CMP1_DAC1 之间选择, 当比较输出为 1 时选择 CMP1_DAC0, 当比较器输出为 0 | RW  | 0x0   |

|  |  |                                                                              |  |  |
|--|--|------------------------------------------------------------------------------|--|--|
|  |  | 时选择 CMP1_DAC1<br>Step=5mV, 0x00~0xF0 对应转换输出为 0~1.2V,<br>0xF0~0xFF 转换输出为 1.2V |  |  |
|--|--|------------------------------------------------------------------------------|--|--|

#### 18.5.14. CMP1\_DAC1

Addr = 0x7D (XSFR)

| Bit(s) | Name      | Description                                                                                  | R/W | Reset |
|--------|-----------|----------------------------------------------------------------------------------------------|-----|-------|
| 7:0    | CMP0_DAC1 | 比较器 1 的 DAC1 寄存器<br>使能数字迟滞时生效<br>Step=5mV, 0x00~0xF0 对应转换输出为 0~1.2V,<br>0xF0~0xFF 转换输出为 1.2V | RW  | 0x0   |

#### 18.5.15. CMP\_CON

Addr = 0x3A (XSFR)

| Bit(s) | Name   | Description                                                         | R/W | Reset |
|--------|--------|---------------------------------------------------------------------|-----|-------|
| 7      | REFEN  | 比较器的参考电压参考电流使能信号<br>0x0: 关闭<br>0x1: 打开                              | RW  | 0x0   |
| 6      | CCSEN  | 恒流源的使能信号<br>0x0: 关闭<br>0x1: 打开                                      | RW  | 0x0   |
| 5:0    | TRIMIB | 恒流源电流调节信号 (step=2.5%)<br>0x00: 11.8mA<br>0x0F: 20mA<br>0x1F: 28.4mA | RW  | 0x0   |

### 18.5.16. CMP\_STA

Addr = 0x3B (XSFR)

| Bit(s) | Name         | Description                                                                         | R/W | Reset |
|--------|--------------|-------------------------------------------------------------------------------------|-----|-------|
| 7      | CMP1WKUPEN   | 比较器1数字信号wakeup使能, 数字唤醒指当比较器中断标志位为1时唤醒<br>0x0: 不使能<br>0x1: 使能                        | RW  | 0x0   |
| 6      | CMPOWKUPEN   | 比较器0数字信号wakeup使能, 数字唤醒指当比较器中断标志位为1时唤醒<br>0x0: 不使能<br>0x1: 使能                        | RW  | 0x0   |
| 5      | CMP1ANAWKP   | 比较器1模拟信号WAKEUP使能, 模拟唤醒指使用比较器的模拟输出进行唤醒, 配置成模拟唤醒后, 可关闭比较器模块的时钟<br>0x0: 不使能<br>0x1: 使能 | RW  | 0x0   |
| 4      | CMPOANAWKP   | 比较器0模拟信号WAKEUP使能, 模拟唤醒指使用比较器的模拟输出进行唤醒, 配置成模拟唤醒后, 可关闭比较器模块的时钟<br>0x0: 不使能<br>0x1: 使能 | RW  | 0x0   |
| 3      | CMP1ANAINVEN | 比较器1模拟WAKEUP取反功能使能<br>0x0: 不使能<br>0x1: 使能                                           | RW  | 0x0   |
| 2      | CMPOANAINVEN | 比较器0模拟WAKEUP取反功能使能<br>0x0: 不使能<br>0x1: 使能                                           | RW  | 0x0   |
| 1      | CMP1PNDCLR   | 比较器1中断标志位, 写1清零                                                                     | RW  | 0x0   |
| 0      | CMPOPNDCLR   | 比较器0中断标志位, 写1清零                                                                     | RW  | 0x0   |

## 19.2.4G RF 收发器模块

### 19.1. 功能描述

TX8W7010 RF 模块子系统是嵌入基带通信协议的 2.4GHz 收发器模块，工作在 2.4GHz~2.483GHz 世界通用的 ISM 频段，适用于超低功耗无线应用领域。该模块集成了射频收发器、频率合成器、多通信模式控制器、调制器、解调器等功能模块。可以对输出功率、频道选择以及协议的设置等用途进行灵活配置。采用 GFSK, FSK 调制，支持 2Mbps, 1Mbps 的数据速率，最大发射功率可以达到 8dBm，接收灵敏度在 1Mbps 速率下可以达到 -90dBm。

#### ● 无线部分特性

- 通信频段：2.400GHz ~ 2.483GHz
- 支持 BLE 广播包
- 支持长包模式（最大 255Byte）
- 数据速率：2Mbps, 1Mbps
- 调制方式：GFSK, FSK
- 126 个射频信道

#### ● 射频综合器

- 完全集成频率合成器
- 不需要外部环路滤波器 (LF) 和压控振荡器 (VCO)
- 可接受低成本的晶体：±60ppm 16MHz 晶体

#### ● 发射器

- 可编程的发射功率：-34 ~ +8 dBm
- 发射功率为 0dBm 时，工作电流为 17mA

#### ● 接收器

- 快速 AGC 功能
- 集成通道滤波器

- 空口速率为 2Mbps 时，工作电流为 18mA
- 空口速率为 2Mbps 时，接收灵敏度为-87dBm
- 空口速率为 1Mbps 时，接收灵敏度为-90dBm

## 19.2. 模块框图



图-18.2 TX8W7010 RF 收发器模块系统结构框图

## 19.3. 寄存器列表

| Address | Register Name | Description              |
|---------|---------------|--------------------------|
| BANK0   |               |                          |
| 0x00    | CONFIG        | BANK0 CONFIG register    |
| 0x01    | EN_AA         | BANK0 EN_AA register     |
| 0x02    | EN_RXADDR     | BANK0 EN_RXADDR register |
| 0x03    | PMU_CTL       | BANK0 PMU_CTL register   |

|       |             |                            |
|-------|-------------|----------------------------|
| 0x04  | SETUP_RETR  | BANK0 SETUP_RETR register  |
| 0x05  | RF_CH       | BANK0 RF_CH register       |
| 0x06  | RF_SETUP    | BANK0 RF_SETUP register    |
| 0x07  | STATUS      | BANK0 STATUS register      |
| 0x0A  | RX_ADDR_P0  | BANK0 RX_ADDR_P0 register  |
| 0x0B  | RX_ADDR_P1  | BANK0 RX_ADDR_P1 register  |
| 0x0C  | RX_ADDR_P2  | BANK0 RX_ADDR_P2 register  |
| 0x10  | TX_ADDR     | BANK0 TX_ADDR register     |
| 0x11  | RX_PW_P0    | BANK0 RX_PW_P0 register    |
| 0x12  | RX_PW_P1    | BANK0 RX_PW_P1 register    |
| 0x13  | RX_PW_P2    | BANK0 RX_PW_P2 register    |
| 0x17  | FIFO_STATUS | BANK0 FIFO_STATUS register |
| 0x18  | CONFIG_EXT  | BANK0 CONFIG_EXT register  |
| 0x1C  | DYNPD       | BANK0 DYNPD register       |
| 0x1D  | FEATURE     | BANK0 FEATURE register     |
| 0x1E  | SETUP_VALUE | BANK0 SETUP_VALUE register |
| 0x1F  | PRE_GURD    | BANK0 PRE_GURD register    |
| BANK1 |             |                            |
| 0x00  | LINE        | BANK1 LINE register        |
| 0x01  | PLL_CTL0    | BANK1 PLL_CTL0 register    |
| 0x02  | PLL_CTL1    | BANK1 PLL_CTL1 register    |
| 0x03  | CAL_CTL     | BANK1 CAL_CTL register     |
| 0x07  | STATUS      | BANK1 STATUS register      |
| 0x08  | STATE       | BANK1 STATE register       |

|      |             |                            |
|------|-------------|----------------------------|
| 0x09 | CHAN        | BANK1 CHAN register        |
| 0x0C | FDEV        | BANK1 FDEV register        |
| 0x0D | DAC_RANGE   | BANK1 DAC_RANGE register   |
| 0x0F | CTUNING     | BANK1 CTUNING register     |
| 0x10 | FTUNING     | BANK1 FTUNING register     |
| 0x11 | RX_CTRL     | BANK1 RX_CTRL register     |
| 0x13 | FAGC_CTRL_1 | BANK1 FAGC_CTRL_1 register |
| 0x1A | DOC_DACI    | BANK1 DOC_DACI register    |
| 0x1B | DOC_DACQ    | BANK1 DOC_DACQ register    |
| 0x1C | AGC_CTRL    | BANK1 AGC_CTRL register    |
| 0x1D | AGC_GAIN    | BANK1 AGC_GAIN register    |
| 0x1E | RF_IVGEN    | BANK1 RF_IVGEN register    |
| 0x1F | TEST_PKDET  | BANK1 TEST_PKDET register  |

## 19.4. 寄存器详细说明

### 19.4.1. CONFIG

Addr = 0x00

| Bit(s) | Name       | Description                                                                                                                                       | R/W | Reset |
|--------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7      | TX_GURD_EN | Bypass tx guard enable                                                                                                                            | RW  | 0x1   |
| 6      | MASK_RX_DR | <b>Mask interrupt caused by RX_DR</b><br>0x0: Reflect RX_DR as active low interrupt on the IRQ pin<br>0x1: Interrupt not reflected on the IRQ pin | RW  | 0x0   |
| 5      | MASK_TX_DS | <b>Mask interrupt caused by TX_DS</b>                                                                                                             | RW  | 0x0   |

|   |             |                                                                                                                                                      |    |     |
|---|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|
|   |             | 0x0: Reflect TX_DS as active low interrupt on the IRQ pin<br>0x1: Interrupt not reflected on the IRQ pin                                             |    |     |
| 4 | MASK_MAX_RT | <b>Mask interrupt caused by MAX_RT</b><br>0x0 : Reflect MAX_RT as active low interrupt on the IRQ pin<br>0x1: Interrupt not reflected on the IRQ pin | W  | 0x0 |
| 3 | EN_CRC      | <b>Enable CRC.</b> Forced high if one of the bits in the EN_AA is high<br>0x0: Disable CRC<br>0x1: Enable CRC                                        | RW | 0x1 |
| 2 | CE_REG      | <b>CE controlled by register</b><br>0x0: chip disable<br>0x1: chip enable                                                                            | RW | 0x0 |
| 1 | PWR_UP      | <b>Power up control</b><br>0x0: POWER DOWN<br>0x1: POWER UP                                                                                          | RW | 0x0 |
| 0 | PRIM_RX     | <b>RX/TX control</b><br>0x0: PTX<br>0x1: PRX                                                                                                         | RW | 0x1 |

#### 19.4.2. EN\_AA

Addr = 0x01

| Bit(s)<br>) | Name     | Description                                                                   | R/W | Reset |
|-------------|----------|-------------------------------------------------------------------------------|-----|-------|
| 7:3         | Reserved |                                                                               | RW  | 0x1   |
| 2           | ENAA_P2  | <b>Enable auto acknowledgement data pipe 2</b><br>0x0: Disable<br>0x1: Enable | RW  | 0x1   |
| 1           | ENAA_P1  | <b>Enable auto acknowledgement data pipe 1</b><br>0x0: Disable<br>0x1: Enable | RW  | 0x1   |

|   |         |                                                                               |    |     |
|---|---------|-------------------------------------------------------------------------------|----|-----|
| 0 | ENAA_P0 | <b>Enable auto acknowledgement data pipe 0</b><br>0x0: Disable<br>0x1: Enable | RW | 0x1 |
|---|---------|-------------------------------------------------------------------------------|----|-----|

### 19.4.3. EN\_RXADDR

Addr = 0x02

| Bit(s)<br>) | Name        | Description                                              | R/W | Reset |
|-------------|-------------|----------------------------------------------------------|-----|-------|
| 7:4         | Reserved    |                                                          | RW  | 0x0   |
| 3           | scramble_en | <b>Scramble enable</b><br>0x0: Disable<br>0x1: Enable    | RW  | 0x1   |
| 2           | ERX_P2      | <b>Enable data pipe 2</b><br>0x0: Disable<br>0x1: Enable | RW  | 0x0   |
| 1           | ERX_P1      | <b>Enable data pipe 1</b><br>0x0: Disable<br>0x1: Enable | RW  | 0x1   |
| 0           | ERX_P0      | <b>Enable data pipe 0</b><br>0x0: Disable<br>0x1: Enable | RW  | 0x1   |

### 19.4.4. PMU\_CTL

Addr = 0x03

| Bit(s)<br>) | Name               | Description                                                                      | R/W | Reset |
|-------------|--------------------|----------------------------------------------------------------------------------|-----|-------|
| 7           | Rtc32k_rdy_enb_reg | <b>For debug mode</b>                                                            | RW  | 0x1   |
| 6           | Rtc32k_rdy_enb_mn  | <b>Rtc32k manual mode select</b><br>0x0: for fsm control<br>0x1: for manual mode | RW  | 0x0   |

|     |                    |                                                                                                                  |    |     |
|-----|--------------------|------------------------------------------------------------------------------------------------------------------|----|-----|
| 5   | Digldo_enb_dly_reg | For debug mode                                                                                                   | RW | 0x1 |
| 4   | Digldo_enb_mn      | <b>Digital ldo manual mode select</b><br>0x0: for fsm control<br>0x1: for manual mode                            | RW | 0x0 |
| 3   | Digldo_enb_reg     | For debug mode                                                                                                   | RW | 0x1 |
| 2   | rtc32k_en          | <b>Rtc32k enable</b><br>0x0: disable<br>0x1: enable                                                              | RW | 0x0 |
| 1:0 | RF_PWRDWN[ 1:0]    | <b>Working mode select</b><br>0x0: active mode<br>0x1: deep sleep mode<br>0x2: light sleep mode<br>0x3: reserved | RW | 0x1 |

#### 19.4.5. SETUP\_RETR

Addr = 0x04

| Bit(s)<br>) | Name | Description                                                                                                                                                    | R/W | Reset |
|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7:4         | ARD  | <b>Auto Retransmit Delay</b><br>0x0: Wait 250μS<br>0x1: Wait 500μS<br>...      ...<br>0xF: Wait 4000μS                                                         | RW  | 0x0   |
| 3:0         | ARC  | <b>Auto Retransmit Count</b><br>0x0: Re-Transmit disabled<br>0x1: Up to 1 Re-Transmit on fail of AA<br>...      ...<br>0xF: Up to 15 Re-Transmit on fail of AA | RW  | 0x3   |

## 19.4.6. RF\_CH

Addr = 0x05

| Bit(s)<br>) | Name      | Description                            | R/W | Reset |
|-------------|-----------|----------------------------------------|-----|-------|
| 7:0         | Reg_Rf_ch | Sets the frequency channel operates on | RW  | 0x32  |

## 19.4.7. RF\_SETUP

Addr = 0x06

| Bit(s)<br>) | Name        | Description                                                                                                                        |                                |               | R/W | Reset |
|-------------|-------------|------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|---------------|-----|-------|
| 7           | CONT_WAVE   | Enables continuous carrier transmit when high<br>0x0: Disable<br>0x1: Enable                                                       |                                |               | R   | 0x0   |
| 6           | PA_PWR[3]   | PA power select bit 3                                                                                                              |                                |               | RW  | 0x1   |
| 5           | CAL_DONE    | Flag for calibration finishing, after CAL_EN set to 1, CAL_DONE will be reset to 0<br>0x0: calibration on<br>0x1: calibration done |                                |               | RW  | 0x0   |
| 4           | CAL_EN      | Calibration enable<br>0x0: Disable<br>0x1: Enable                                                                                  |                                |               | RW  | 0x0   |
| 3           | RF_DR_HIGH  | Data rate select<br>0x0: for 1Mbps<br>0x1: for 2Mbps                                                                               |                                |               | R   | 0x1   |
| 2:0         | PA_PWR[2:0] | PA power control, PA_PWR[3:0] with pa_voltage of RF_IVGEN in bank1                                                                 |                                |               | R   | 0x0   |
|             |             | PA_PWR[3:0]                                                                                                                        | Pa_voltage (bank1 of RF_IVGEN) | Description   | RW  | 0x0   |
|             |             | 1111                                                                                                                               | 0                              | Output 8 dbm, |     |       |
|             |             | 1000                                                                                                                               | 0                              | Output 5 dbm  |     |       |
|             |             | 0111                                                                                                                               | 1                              | Output 4dbm,  |     |       |
|             |             | 0011                                                                                                                               | 0                              | Output 0 dbm, |     |       |

|  |  |      |   |                |  |  |
|--|--|------|---|----------------|--|--|
|  |  | 0001 | 0 | Output -6 dbm  |  |  |
|  |  | 0001 | 1 | Output -12 dbm |  |  |
|  |  | 0000 | 0 | Output -16 dbm |  |  |
|  |  | 0000 | 1 | Output -43 dbm |  |  |

#### 19.4.8. STATUS

Addr = 0x07

| Bit(s) | Name    | Description                                                                                                                         | R/W | Reset |
|--------|---------|-------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7      | BANK    | <b>Register BANK status</b><br>0x0: Register R/W is to register BANK0<br>0x1: Register R/W is to register BANK1                     | R   | 0x0   |
| 6      | RX_DR   | <b>Data Ready RX FIFO interrupt.</b> Asserted when new data arrives RX FIFO<br><b>Write 1 to clear bit.</b>                         | RW  | 0x0   |
| 5      | TX_DS   | <b>Data Sent TX FIFO interrupt.</b> Asserted when packet transmitted on TX. Write 1 to clear bit.                                   | RW  | 0x0   |
| 4      | SYNC_DS | <b>RX sync detector interrupt,</b> Write 1 to clear bit. If SYNC_DS is asserted it must be cleared to enable further communication. | RW  | 0x0   |
| 3      | CE      | <b>CE state</b>                                                                                                                     | R   | 0x0   |
| 2:1    | RX_P_NO | <b>Data pipe number for the payload available for reading from RX_FIFO</b><br>0x0~0x2: Data Pipe Number<br>0x3: RX FIFO Empty       | R   | 0x3   |
| 0      | TX_FULL | <b>TX FIFO full flag</b><br>0x0: Available locations in TX FIFO<br>0x1: TX FIFO full                                                | R   | 0x0   |

#### 19.4.9. RX\_ADDR\_P0

Addr = 0x0A

| Bit(s) | Name       | Description                                                                                                                   | R/W | Reset            |
|--------|------------|-------------------------------------------------------------------------------------------------------------------------------|-----|------------------|
| 39:0   | RX_ADDR_P0 | Receive address data pipe 0. 5 Bytes maximum length. (LSByte is written first. Write the number of bytes defined by SETUP_AW) | RW  | 0x7041<br>882046 |

#### 19.4.10. RX\_ADDR\_P1

Addr = 0x0B

| Bit(s) | Name       | Description                                                                  | R/W | Reset  |
|--------|------------|------------------------------------------------------------------------------|-----|--------|
| 7:0    | RX_ADDR_P1 | Receive address data pipe 2. Only LSB. MSBytes are equal to RX_ADDR_P0[39:8] | RW  | 8' hc2 |

#### 19.4.11. RX\_ADDR\_P2

Addr = 0x0C

| Bit(s) | Name       | Description                                                                  | R/W | Reset  |
|--------|------------|------------------------------------------------------------------------------|-----|--------|
| 7:0    | RX_ADDR_P2 | Receive address data pipe 2. Only LSB. MSBytes are equal to RX_ADDR_P0[39:8] | RW  | 8' hc3 |

#### 19.4.12. TX\_ADDR

Addr = 0x10

| Bit(s) | Name    | Description                                                                                                                                                                                        | R/W | Reset            |
|--------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|------------------|
| 39:0   | TX_ADDR | Transmit address. Used for a PTX device only. (LSByte is written first) Set RX_ADDR_P0 equal to this address to handle automatic acknowledge if this is a PTX device with Protocol engine enabled. | RW  | 0x7041<br>882046 |

### 19.4.13. RX\_PW\_P0

**Note:** The register has two definition for 2.4G mode and 2.4G long packet mode respectively .

Addr = 0x11

2.4G Mode

| Bit(s)<br>) | Name     | Description                                                                                                                                                | R/W | Reset |
|-------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7:6         | Reserved |                                                                                                                                                            | RW  | 0x0   |
| 5:0         | RX_PW_P0 | <b>Number of bytes in RX payload in data pipe 0 (1 to 32 bytes)</b><br>0x00: Pipe not used<br>0x01: 1 byte<br>...   ...<br>0x2D: 31 bytes<br>0x2F: 32bytes | RW  | 0x0   |

2.4G long packet mode

| Bit(s)<br>) | Name                  | Description                                           | R/W | Reset |
|-------------|-----------------------|-------------------------------------------------------|-----|-------|
| 7:0         | Long_packet_length_p0 | <b>Payload length of 2.4G long packet mode, 0~255</b> | RW  | 0x0   |

### 19.4.14. RX\_PW\_P1

**Note:** The register has two definition for 2.4G mode and 2.4G long packet mode respectively .

Addr = 0x12

2.4G Mode

| Bit(s)<br>) | Name     | Description                                                                                | R/W | Reset |
|-------------|----------|--------------------------------------------------------------------------------------------|-----|-------|
| 7:6         | Reserved |                                                                                            | RW  | 0x0   |
| 5:0         | RX_PW_P1 | <b>Number of bytes in RX payload in data pipe 0 (1 to 32 bytes)</b><br>0x00: Pipe not used | RW  | 0x0   |

|  |  |                                                            |  |  |
|--|--|------------------------------------------------------------|--|--|
|  |  | 0x01: 1 byte<br>... ...<br>0x2D: 31 bytes<br>0x2F: 32bytes |  |  |
|--|--|------------------------------------------------------------|--|--|

2. 4G long packet mode

| Bit(s)<br>) | Name                  | Description                                    | R/W | Reset |
|-------------|-----------------------|------------------------------------------------|-----|-------|
| 7:0         | Long_packet_length_p1 | Payload length of 2.4G long packet mode, 0~255 | RW  | 0x0   |

#### 19. 4. 15. RX\_PW\_P2

*Note:* The register has two definition for 2.4G mode and 2.4G long packet mode respectively .

Addr = 0x13

2. 4G mode

| Bit(s)<br>) | Name     | Description                                                                                                                                       | R/W | Reset |
|-------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7:6         | Reserved |                                                                                                                                                   | RW  | 0x0   |
| 5:0         | RX_PW_P2 | Number of bytes in RX payload in data pipe 0 (1 to 32 bytes)<br>0x00: Pipe not used<br>0x01: 1 byte<br>... ...<br>0x2D: 31 bytes<br>0x2F: 32bytes | RW  | 0x0   |

2. 4G long packet mode

| Bit(s)<br>) | Name                  | Description                                    | R/W | Reset |
|-------------|-----------------------|------------------------------------------------|-----|-------|
| 7:0         | Long_packet_length_p2 | Payload length of 2.4G long packet mode, 0~255 | RW  | 0x0   |

#### 19.4.16. FIFO\_STATUS

Addr = 0x17

| Bit(s)<br>) | Name        | Description                                                                             | R/W | Reset |
|-------------|-------------|-----------------------------------------------------------------------------------------|-----|-------|
| 7           | Reserved    | <b>Only '0' allowed</b><br>0x0: Keep the current value<br>0x1: Reset to default values  | RW  | 0x0   |
| 6           | TX_REUSE_PL | <b>TX REUSE flag.</b><br>0x0: Tx data not reused<br>0x1: Tx data reused                 | R   | 0x0   |
| 5           | TX_FULL     | <b>TX FIFO full flag.</b><br>0x0: Available locations in TX FIFO<br>0x1: TX FIFO full   | R   | 0x0   |
| 4           | TX_EMPTY    | <b>TX FIFO empty flag.</b><br>0x0: Data in TX FIFO<br>0x1: TX FIFO empty                | R   | 0x1   |
| 3:2         | Reserved    | <b>Only '00' allowed</b><br>0x0: Keep the current value<br>0x1: Reset to default values | RW  | 0x0   |
| 1           | RX_FULL     | <b>RX FIFO full flag.</b><br>0x0: Available locations in RX FIFO<br>0x1: RX FIFO full   | R   | 0x0   |
| 0           | RX_EMPTY    | <b>RX FIFO empty flag.</b><br>0x0: Data in RX FIFO<br>0x1: RX FIFO empty                | R   | 0x1   |

#### 19.4.17. CONFIG\_EXT

Addr = 0x18

| Bit(s)<br>) | Name         | Description | R/W | Reset |
|-------------|--------------|-------------|-----|-------|
| 7:4         | Reserved     |             | RW  | 0x1   |
| 3           | msk_rx_afull |             | RW  | 0x1   |

|     |               |  |    |     |
|-----|---------------|--|----|-----|
| 2   | msk_tx_aempty |  | RW | 0x1 |
| 1:0 | Reserved      |  | RW | 0x2 |

#### 19.4.18. DYNPD

Addr = 0x1C

| Bit(s) | Name          | Description                                                              | R/W | Reset |
|--------|---------------|--------------------------------------------------------------------------|-----|-------|
| 7      | Reg_output    | Register control IRQ output                                              | RW  | 0x0   |
| 6      | Reg_output_en | Register control IRQ output enable                                       | RW  | 0x0   |
| 5      | Bypass_io     | Bypass IRQ and MOSI, after power up,<br>Bypass_io should be set 0        | RW  | 0x1   |
| 4      | Xn_en         | Xn mode enable                                                           | RW  | 0x0   |
| 3      | Spi4_en       | 4-wire SPI enable                                                        | RW  | 0x0   |
| 2      | DPL_P2        | Enable dynamic payload length data pipe 2. (Requires EN_DPL and ENAA_P2) | RW  | 0x0   |
| 1      | DPL_P1        | Enable dynamic payload length data pipe 1. (Requires EN_DPL and ENAA_P1) | RW  | 0x0   |
| 0      | DPL_P0        | Enable dynamic payload length data pipe 0. (Requires EN_DPL and ENAA_P0) | RW  | 0x0   |

#### 19.4.19. FEATURE

Addr = 0x1D

| Bit(s) | Name           | Description                                                                                                | R/W | Reset |
|--------|----------------|------------------------------------------------------------------------------------------------------------|-----|-------|
| 7      | Long_packet_en | Long packet mode enable                                                                                    | RW  | 0x0   |
| 6      | Ble_en         | BLE mode enable                                                                                            | RW  | 0x0   |
| 5      | Soft_RST       | Software reset                                                                                             | RW  | 0x0   |
| 4      | BP_GAU         | Bypass Gaussian filter, BLE mode should not bypass Gaussian filter                                         | RW  | 0x1   |
| 3      | Vco_amp_tx_mux | Vco_amp_tx_mux=0, vco_amp_ctr[3:0] (VCO amplitude control bit) of RX and TX are both from calibration fsm; | RW  | 0x1   |

|   |            |                                                                                                            |    |     |
|---|------------|------------------------------------------------------------------------------------------------------------|----|-----|
|   |            | Vco_amp_tx_mux=1, vco_amp_ctr[3:0] of RX is from calibration fsm, vco_amp_ctr[3:0] of TX is fixed to 0x0c; |    |     |
| 2 | EN_DPL     | Enables Dynamic Payload Length                                                                             | RW | 0x0 |
| 1 | EN_ACK_PAY | Enables Payload with ACK                                                                                   | RW | 0x0 |
| 0 | EN_DYN_ACK | Enables the W_TX_PAYLOAD_NOACK command                                                                     | RW | 0x0 |

#### 19.4.20. SETUP\_VALUE

Addr = 0x1E

| Bit(s) | Name          | Description                                                                | R/W | Reset |
|--------|---------------|----------------------------------------------------------------------------|-----|-------|
| 23:16  | REG_LNA_WA_IT | Lna wait counter<br>0x0: 0 cycle<br>0x1: 1 cycle<br>...<br>0xFF: 255 cycle | RW  | 0x0   |
| 15:8   | REG_MBG_W_AIT | Main bandgap wait counter<br>0x0: 0 us<br>0x1: 1 us<br>...<br>0xFF: 255 us | RW  | 0x6   |
| 7:0    | RX_TM_CNT     | Rx timeout counter.<br>0x0: 0 us<br>0x1: 1 us<br>...<br>0xFF: 255 us       | RW  | 0x80  |

#### 19.4.21. PRE\_GURD

Addr = 0x1F

| Bit(s) | Name | Description | R/W | Reset |
|--------|------|-------------|-----|-------|
|        |      |             |     |       |

|      |           |                                                                                                                                    |    |     |
|------|-----------|------------------------------------------------------------------------------------------------------------------------------------|----|-----|
| )    |           |                                                                                                                                    |    |     |
| 15:8 | SPARE_REG | Reserved register                                                                                                                  | RW | 0x0 |
| 7:5  | TAIL_CTL  | <b>Number of repeat bit after the CRC</b><br>0x0: 0 No repeat tail<br>0x1: 1 repeat tail<br>... ...<br>0x7: 7 repeat tail          | RW | 0x3 |
| 4    | GRD_EN    | <b>Pre-Guard enable</b>                                                                                                            | RW | 0x1 |
| 3:0  | GRD_CNT   | <b>Number of Pre-Guard bit before preamble</b><br>0x0: 1 bit pre_guard<br>0x1: 2 bit pre_guard<br>... ...<br>0xF: 16 bit pre_guard | RW | 0x7 |

#### 19.4.22. LINE

Addr = 0x00

| Bit(s)<br>) | Name | Description    | R/W | Reset |
|-------------|------|----------------|-----|-------|
| 15:0        | CID  | <b>Chip ID</b> | R   | 0x600 |

#### 19.4.23. PLL\_CTL0

Addr = 0x01

| Bit(s)<br>) | Name         | Description                                                      | R/W | Reset |
|-------------|--------------|------------------------------------------------------------------|-----|-------|
| 31          | SDM_EN       | <b>SDM enable</b><br>0x0: Disable the SDM<br>0x1: Enable the SDM | RW  | 0x1   |
| 30          | Pll_dac_en   | <b>Output DAC_EN to analog</b><br>0x0: Output 0<br>0x1: Output 1 | RW  | 0x1   |
| 29          | PLL_RSTN_PFD | <b>PLL_RSTN_PFD control</b><br>0x0: Set 0                        | RW  | 0x1   |

|       |                 |                                                                                                                             |    |     |
|-------|-----------------|-----------------------------------------------------------------------------------------------------------------------------|----|-----|
|       |                 | 0x1: Set 1                                                                                                                  |    |     |
| 28    | CRY_PD_REG      | <b>Control the Power down of Crystal</b><br>0x0: Power up the crystal<br>0x1: Power down the crystal                        | RW | 0x0 |
| 27    | CRY_PD_MN       | <b>Select the source of crystal power down</b><br>0x0: CRY_PD = CRY_PD_FSM<br>0x1: CRY_PD = CRY_PD_REG                      | RW | 0x0 |
| 26    | Reserved        |                                                                                                                             | RW | 0x0 |
| 25:24 | PLL_FOFFSET_SEL | <b>PLL_FOFFSET_SEL control</b>                                                                                              | RW | 0x1 |
| 23    | DAC_CAL_EN_REG  | <b>DAC calibration enable</b><br>0x0: Disable the DAC calibration<br>0x1: Enable the DAC calibration                        | RW | 0x0 |
| 22    | DAC_CAL_EN_MN   | <b>Select the source of DAC_CAL_EN</b><br>0x0: DAC_CAL_EN = DAC_CAL_FSM<br>0x1: DAC_CAL_EN = DAC_CAL_REG                    | RW | 0x0 |
| 21    | DAC_CALMODE_REG | <b>Control the VCO gain</b><br>0x0: 5 times of the normal gain<br>0x1: Normal gain                                          | RW | 0x0 |
| 20    | BP_RC_BP        | <b>Bypass RC_BP phase in the FSM</b><br>0x0: No bypass RC_BP phase<br>0x1: Bypass RC_BP phase                               | RW | 0x1 |
| 19    | DOC_CAL_EN_REG  | <b>Enable the DOC calibration</b><br>0x0: Disable the DOC calibration<br>0x1: Enable the DOC calibration                    | RW | 0x0 |
| 18    | DOC_CAL_EN_MN   | <b>Select the source of DOC_CAL_EN source</b><br>0x0:<br>DOC_CAL_EN = DOC_CAL_EN_FSM<br>0x1:<br>DOC_CAL_EN = DOC_CAL_EN_REG | RW | 0x0 |
| 17    | DOC_DAC_M_N     | <b>Select the source of DOC source</b><br>0x0:<br>DOC_DACI = DOC_DACI_FSM                                                   | RW | 0x0 |

|    |                |                                                                                                                             |    |     |
|----|----------------|-----------------------------------------------------------------------------------------------------------------------------|----|-----|
|    |                | <b>DOC_DACQ = DOC_DACQ_FSM</b><br>0x1:<br><b>DOC_DACI = DOC_DACI_REG</b><br><b>DOC_DACQ=DOC_DACQ_REG</b>                    |    |     |
| 16 | I_q_rvs        | <b>Only 0 allowed</b><br>0x0: Keep the current value<br>0x1: Reset to default values                                        | RW | 0x0 |
| 15 | PLL_TEST_EN    | <b>Enable the PLL in test mode</b><br>0x0: PLL A_CNT and B_CNT come from SDM<br>0x1: PLL A_CNT and B_CNT come from register | RW | 0x0 |
| 14 | pd_pkdet_reg   | <b>Manual mode of pd_pkdet register</b>                                                                                     | RW | 0x0 |
| 13 | pd_pkdet_mn    | <b>Manual mode of pd_pkdet enable</b>                                                                                       | RW | 0x0 |
| 12 | PD_PLL_REG     | <b>PLL power down control</b><br>0x0: Power up PLL<br>0x1: Power down PLL                                                   | RW | 0x0 |
| 11 | PD_PLL_MN      | <b>Select the source of PLL Power down</b><br>0x0: PD_PLL = PD_PLL_FSM<br>0x1: PD_PLL = PD_PLL_REG                          | RW | 0x0 |
| 10 | PLL_TX_EN_R EG | <b>PLL TX mode</b><br>0x0: PLL in RX mode<br>0x1: PLL in TX mode                                                            | RW | 0x0 |
| 9  | PLL_TX_EN_ MN  | <b>Select the source of PLL_TX_EN</b><br>0x0: PLL_TX_EN = PLL_TX_EN_FSM<br>0x1: PLL_TX_EN = PLL_TX_EN_REG                   | RW | 0x0 |
| 8  | BYPASS_VCO_RES | <b>Bypass VCO tail resistor for max amplitude</b>                                                                           | RW | 0x0 |
| 7  | SDM_DITH_IN    | <b>SDM dither in value</b><br>0x0: Value 0<br>0x1: Value 1                                                                  | RW | 0x0 |
| 6  | SDM_DITH_E N   | <b>SDM dither enable</b><br>0x0: Disable the SDM dither<br>0x1: Enable the SDM dither                                       | RW | 0x0 |
| 5  | DAC_RANG_ MN   | <b>Select the source of DAC_RANG</b>                                                                                        | RW | 0x0 |

|   |              |                                                                                                 |    |     |
|---|--------------|-------------------------------------------------------------------------------------------------|----|-----|
|   |              | 0x0: DAC_RANG = DAC_RANG_FSM<br>0x1: DAC_RANG = DAC_RANG_REG                                    |    |     |
| 4 | SYNC_DET_DIS | <b>Disable AGC when sync detected</b>                                                           | RW | 0x0 |
| 3 | AFC_EN_REG   | <b>AFC enable</b><br>0x0: Disable the AFC<br>0x1: Enable the AFC                                | RW | 0x0 |
| 2 | AFC_EN_MN    | <b>Select the source of AFC_EN</b><br>0x0: AFC_EN = AFC_EN_FSM<br>0x1: AFC_EN = AFC_EN_REG      | RW | 0x0 |
| 1 | CTUNING_MN   | <b>Select the source of CTUNING</b><br>0x0: CTUNING = CTUNING_FSM<br>0x1: CTUNING = CTUNING_REG | RW | 0x0 |
| 0 | FTUNING_MN   | <b>Select the source of FTUNING</b><br>0x0: FTUNING = FTUNING_FSM<br>0x1: FTUNING = FTUNING_REG | RW | 0x0 |

#### 19.4.24. PLL\_CTL1

Addr = 0x02

| Bit(s)<br>) | Name           | Description                                                                                             | R/W | Reset |
|-------------|----------------|---------------------------------------------------------------------------------------------------------|-----|-------|
| 23:16       | REG_TX_PA_WAIT | The time between power up PA to transmit data<br>0x0: 0 cycle<br>0x1: 1 cycle<br>...<br>0xFF: 255 cycle | RW  | 0x2   |
| 15:8        | Tx_PLL_WAIT    | Pll lock wait time in Tx mode<br>0x0: 0 us<br>0x1: 1 us<br>...<br>0xFF: 255 us                          | RW  | 0x42  |
| 7:0         | REG_AFC_WAIT   | The time between RC done and AFC start<br>0x0: 0 us                                                     | RW  | 0x0   |

|  |  |                                           |  |  |
|--|--|-------------------------------------------|--|--|
|  |  | 0x1: 1 us<br>...      ...<br>0xFF: 255 us |  |  |
|--|--|-------------------------------------------|--|--|

#### 19.4.25. CAL\_CTL

Addr = 0x03

| Bit(s)<br>) | Name        | Description                                                                                | R/W | Reset |
|-------------|-------------|--------------------------------------------------------------------------------------------|-----|-------|
| 31:24       | Rx_pll_wait | P11 lock wait time in rx mode Force_cal : before every transmit and receive do calibration | RW  | 0x28  |
| 23          | Reserved    |                                                                                            | RW  | 0x0   |
| 22:21       | afc_w_sel   | Select the AFC wait reference counter<br>0x0: 512<br>0x1: 255<br>0x2: 127<br>0x3: 63       | RW  | 0x11  |
| 20          | -           | -                                                                                          | RW  | 0x1   |
| 19          | Bp_dc       | Bypass DC calibration phase<br>0x0: Disable<br>0x1: Enable                                 | RW  | 0x0   |
| 18          | Bp_dac      | Bypass DAC calibration phase<br>0x0: Disable<br>0x1: Enable                                | RW  | 0x0   |
| 17          | Bp_afc      | Bypass AFC calibration phase<br>0x0: Disable<br>0x1: Enable                                | RW  | 0x0   |
| 16          | Bp_rc       | Bypass RC calibration phase<br>0x0: Disable<br>0x1: Enable                                 | RW  | 0x0   |
| 15          | bp_vco_ldo  | Bypass VCO_LDO calibration phase<br>0x0: Disable<br>0x1: Enable                            | RW  | 0x0   |

|      |                 |                                                                                                              |    |     |
|------|-----------------|--------------------------------------------------------------------------------------------------------------|----|-----|
| 14   | Psudo_rnd       | <b>Transmit Random data</b><br>0x0: Disable<br>0x1: Enable                                                   | RW | 0x0 |
| 13   | Bp_rx_addr      | <b>Bypass the RX_ADDR phase in the main FSM</b>                                                              | RW | 0x0 |
| 12   | bp_vco_amp      | <b>Bypass VCO amplitude calibration phase</b><br>0x0: Disable<br>0x1: Enable                                 | RW | 0x0 |
| 11   | Bp_cp_diox      | <b>Bpassdio</b><br>0x0: Disable<br>0x1: Enable                                                               | RW | 0x1 |
| 10:8 | Vco_ldo_cal_reg | <b>Vco_ldo manual set value</b>                                                                              |    | 0x0 |
| 7    | Vco_ldo_cal_mn  | <b>Vcoldo calibration select</b><br>0x0: Vco_ldo_cal = vco_ldo_cal_fsm<br>0x1: Vco_ldo_cal = vco_ldo_cal_reg | RW | 0x0 |
| 6    | Rc_cal_ctr_mn   | <b>Rc calibration select</b><br>0x0: Rc_cal_ctrl = rc_cal_ctrl_fsm<br>0x1: Rc_cal_ctrl = rc_cal_ctrl_reg     | RW | 0x0 |
| 5    | Pl1_RST_CNT     | <b>Pl1_RST_CNT</b><br>0x0: Output 0<br>0x1: Output 1                                                         | RW | 0x1 |
| 4:0  | Rc_cal_ctrl_reg | <b>Rc calibration register</b>                                                                               | RW | 0x0 |

#### 19.4.26. STATUS

Addr = 0x07

| Bit(s) | Name  | Description                                                                                                     | R/W | Reset |
|--------|-------|-----------------------------------------------------------------------------------------------------------------|-----|-------|
| 7      | BANK  | <b>Register BANK status</b><br>0x0: Register R/W is to register BANK0<br>0x1: Register R/W is to register BANK1 | R   | 0x0   |
| 6      | RX_DR | <b>Data Ready RX FIFO interrupt.</b> Asserted when new data arrives RX FIFO<br><b>Write 1 to clear bit.</b>     | RW  | 0x0   |

|     |         |                                                                                                                              |    |     |
|-----|---------|------------------------------------------------------------------------------------------------------------------------------|----|-----|
| 5   | TX_DS   | Data Sent TX FIFO interrupt. Asserted when packet transmitted on TX. Write 1 to clear bit.                                   | RW | 0x0 |
| 4   | SYNC_DS | RX sync detector interrupt, Write 1 to clear bit. If SYNC_DS is asserted it must be cleared to enable further communication. | RW | 0x0 |
| 3   | CE      | CE state                                                                                                                     | R  | 0x0 |
| 2:1 | RX_P_NO | Data pipe number for the payload available for reading from RX_FIFO<br>0x3: RX FIFO Empty<br>0x0~0x2: Data Pipe Number       | R  | 0x3 |
| 0   | TX_FULL | TX FIFO full flag<br>0x0: Available locations in TX FIFO<br>0x1: TX FIFO full                                                | R  | 0x0 |

#### 19.4.27. STATE

Addr = 0x08

| Bit(s) | Name      | Description                                                                   | R/W | Reset |
|--------|-----------|-------------------------------------------------------------------------------|-----|-------|
| 15:12  | Reserved  |                                                                               | RW  | 0x0   |
| 11:8   | Cal_st_cs | Describe the state of calibration state machine                               | R   | 0x0   |
| 7:6    | Reserved  | Only 0 allowed<br>0x0: Keep the current value<br>0x1: Reset to default values | RW  | 0x0   |
| 5:0    | State_cs  | Describe the state of main state machine                                      | R   | 0x0   |

#### 19.4.28. CHAN

Addr = 0x09

| Bit(s) | Name | Description | R/W | Reset |
|--------|------|-------------|-----|-------|
|        |      |             |     |       |

|      |               |                                                                                                                 |    |     |
|------|---------------|-----------------------------------------------------------------------------------------------------------------|----|-----|
| )    |               |                                                                                                                 |    |     |
| 31   | Chan_mn       | <b>Channel int and frac part select</b><br>0x0: Come from the calculation from rf_ch<br>0x1: Come from register | RW | 0x0 |
| 30   | Reserved      | <b>Only 0 allowed</b><br>0x0: Keep the current value<br>0x1: Reset to default values                            | RW | 0x0 |
| 29:9 | CHAN_FRAC_REG | <b>PLL frequency fragment pat</b>                                                                               | RW | 0x0 |
| 8:0  | CHAN_INT_REG  | <b>PLL frequency integer pat</b>                                                                                | RW | 0x0 |

#### 19.4.29. FDEV

Addr = 0x0C

| Bit(s)<br>) | Name     | Description                     | R/W | Reset |
|-------------|----------|---------------------------------|-----|-------|
| 7           | Reserved | -                               | R   | 0x0   |
| 6:0         | FDEV     | The max offset of the frequency | RW  | 0x20  |

#### 19.4.30. DAC\_RANGE

Addr = 0x0D

| Bit(s) | Name          | Description                                                                          | R/W | Reset |
|--------|---------------|--------------------------------------------------------------------------------------|-----|-------|
| 7:6    | Reserved      | <b>Only 0 allowed</b><br>0x0: Keep the current value<br>0x1: Reset to default values | R   | 0x0   |
| 5:0    | DAC_RANGE_REG | <b>DAC calibration Range control</b>                                                 | RW  | 0x0   |

#### 19.4.31. CTUNING

Addr = 0x0F

| Bit(s) | Name | Description | R/W | Reset |
|--------|------|-------------|-----|-------|
|        |      |             |     |       |

|       |                |                                                                                      |    |     |
|-------|----------------|--------------------------------------------------------------------------------------|----|-----|
| )     |                |                                                                                      |    |     |
| 15:13 | Reserved       | <b>Only 0 allowed</b><br>0x0: Keep the current value<br>0x1: Reset to default values | R  | 0x0 |
| 12:8  | CTUNING_REG_RX | <b>AFC coarse tuning register control</b>                                            | RW | 0x0 |
| 7:5   | Reserved       | <b>Only 0 allowed</b><br>0x0: Keep the current value<br>0x1: Reset to default values | R  | 0x0 |
| 4:0   | CTUNING_REG_TX | <b>AFC coarse tuning register control</b>                                            | RW | 0x0 |

#### 19.4.32. FTUNING

Addr = 0x10

| Bit(s)<br>) | Name           | Description                                                                          | R/W | Reset |
|-------------|----------------|--------------------------------------------------------------------------------------|-----|-------|
| 15:11       | Reserved       | <b>Only 0 allowed</b><br>0x0: Keep the current value<br>0x1: Reset to default values | R   | 0x0   |
| 10:8        | FTUNING_REG_RX | <b>AFC fine tuning register control</b>                                              | RW  | 0x0   |
| 7:3         | Reserved       | <b>Only 0 allowed</b><br>0x0: Keep the current value<br>0x1: Reset to default values | R   | 0x0   |
| 2:0         | FTUNING_REG_TX | <b>AFC fine tuning register control</b>                                              | RW  | 0x0   |

#### 19.4.33. RX\_CTRL

Addr = 0x11

| Bit(s)    | Name       | Description                         | R/W | Reset |
|-----------|------------|-------------------------------------|-----|-------|
| 15:1<br>3 | sbe_max_th | <b>Sync address error tolerance</b> | RW  | 0x01  |
| 12:6      | xcorr_th   | <b>Sync threshold</b>               | RW  | 0x50  |

|     |               |                                            |    |      |
|-----|---------------|--------------------------------------------|----|------|
| 5   | en_dc_removal | Dc remove enable                           | RW | 0x01 |
| 4   | en_sbe        | Sbe enable                                 | RW | 0x01 |
| 3:2 | Reserved      | -                                          | RW | 0x01 |
| 1:0 | h_idx         | modualtion index<br>0x1: 0.32<br>0x2: 0.50 | RW | 0x2  |

#### 19.4.34. FAGC\_CTRL\_1

Addr = 0x13

| Bit(s)    | Name           | Description                              | R/W | Reset |
|-----------|----------------|------------------------------------------|-----|-------|
| 31:2<br>9 | reserved       | -                                        | RW  | 0x0   |
| 28:2<br>6 | pkdet_vrefc    | Pkdetvrefc value                         | RW  | 0x2   |
| 25:2<br>4 | pkdet_vref2c   | Pkdet vref2c value                       | RW  | 0x1   |
| 23        | reserved       | -                                        | RW  | 0x0   |
| 22:1<br>2 | agc_dpd_lo_thr | Agc_dpd_lo threshold                     | RW  | 0x81  |
| 11:9      | reserved       | -                                        | RW  | 0x0   |
| 8         | VCO_AMP_MN     | Manual mode of VCO amplitude calibration | RW  | 0x0   |
| 7:4       | VCO_AMP_CTL    | VCO amplitude control                    | RW  | 0x0   |
| 3:0       | VCO_PKREF_CTL  | VCO amplitude calibration reference      | RW  | 0x3   |

#### 19.4.35. DOC\_DACI

Addr = 0x1A

| Bit(s) | Name     | Description    | R/W | Reset |
|--------|----------|----------------|-----|-------|
| 7      | Reserved | Only 0 allowed | RW  | 0x0   |

|     |          |                                                             |    |     |
|-----|----------|-------------------------------------------------------------|----|-----|
|     |          | 0x0: Keep the current value<br>0x1: Reset to default values |    |     |
| 6:0 | doc_daci | <b>Doc calibration daci value</b>                           | RW | 0x0 |

#### 19.4.36. DOC\_DACQ

Addr = 0x1B

| Bit(s)<br>) | Name     | Description                                                                              | R/W | Reset |
|-------------|----------|------------------------------------------------------------------------------------------|-----|-------|
| 7           | Reserved | <b>Only 0 allowed</b><br><br>0x0: Keep the current value<br>0x1: Reset to default values | RW  | 0x0   |
| 6:0         | doc_dacq | <b>Doc calibration dacq value</b>                                                        | RW  | 0x0   |

#### 19.4.37. AGC\_CTRL

Addr = 0x1C

| Bit(s)<br>) | Name          | Description                                                                                                                                                                     | R/W | Reset |
|-------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 23          | test_pat_en   | <b>Test pattern enable</b>                                                                                                                                                      | RW  | 0x0   |
| 22:20       | adp_samp_mode | <b>Number of clock cycles delay between every two apd detection</b><br><br>0x0: 0 cycles<br>0x1: 2 cycles<br>0x2: 4 cycles<br>0x3: 8 cycles<br>0x4: 16 cycles<br>0x5: 32 cycles | RW  | 0x0   |
| 19:18       | agc_samp_mode | <b>The number of shift registers which are required for Dpd calculation</b><br><br>0x0: 2 registers<br>0x1: 4 registers<br>0x2: 8 registers<br>0x3: 16 registers                | RW  | 0x2   |
| 17          | agc_dpd_mode  | <b>AGC DPD MODE select</b><br><br>0x0: mean of sample amplitudes<br>0x1: max of sample amplitudes                                                                               | RW  | 0x0   |

|       |                |                                                                                 |    |       |
|-------|----------------|---------------------------------------------------------------------------------|----|-------|
| 16:11 | agc_dpd_thr_db | dB value of dpd_hi_th minus back off dB value of the Dpd which is 3 in default. | RW | 0x33  |
| 10:0  | agc_dpd_thr    | Default threshold when dpd is detected.                                         | RW | 0x200 |

#### 19.4.38. AGC\_GAIN

Addr = 0x1d

| Bit(s) | Name                | Description                                                                                                                                                                                                        | R/W | Reset |
|--------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31     | agc_gain_mn         | Agc output gain is get from software or hardware calculation<br>0x0: From hardware<br>0x1: From software                                                                                                           | RW  | 0x0   |
| 30:26  | apd_clr_cnt_th[4:0] | Analog Gsw+Gsetl time interval                                                                                                                                                                                     | RW  | 0x7   |
| 25:21  | apd_det_cnt_th[4:0] | Apd detection time interval                                                                                                                                                                                        | RW  | 0x7   |
| 20:15  | dpd_clr_cnt_th[5:0] | Digital Gsw+Gsetl time interval, and add Dpd detection time interval                                                                                                                                               | RW  | 0x17  |
| 14:13  | reserved            |                                                                                                                                                                                                                    | RW  | 0x2   |
| 12:11  | Agc_apd_state_rg    | When agc_gain_mn is 1, the value read from this register is the Lna gain given by the software. When agc_gain_mn is 0, the value read from this register is the Lna gain calculated from the hardware module       | RW  | 0x0   |
| 10:0   | Agc_dpd_state_rg    | When agc_gain_mn is 1, the value read from this register is the filter gain given by the software. When agc_gain_mn is 0, the value read from this register is the filter gain calculated from the hardware module | RW  | 0x101 |

#### 19.4.39. RF\_IVGEN

Addr = 0x1e

| Bit(s)<br>) | Name           | Description                                                                                                | R/W | Reset |
|-------------|----------------|------------------------------------------------------------------------------------------------------------|-----|-------|
| 23          | Calib_rx_reg   | <b>Manual calibration TX/RX select</b><br>0x0: Manual calibration for TX<br>0x1: Manual calibration for RX | RW  | 0x1   |
| 22          | Tx_0_1_rvs     | <b>TX 0/1 reverse</b><br>0x0: Not reverse<br>0x1: Reverse the 0/1 when transmit                            | RW  | 0x0   |
| 21          | Pd_lna_reg     | <b>Pd_lna manual value</b>                                                                                 | RW  | 0x0   |
| 20          | Pd_lna_mn      | <b>Pd_lna manual select</b><br>0x0: From FSM<br>0x1: from register                                         | RW  | 0x0   |
| 19          | Pd_pa_reg      | <b>Pd_pa manual value</b>                                                                                  | RW  | 0x0   |
| 18          | Pd_pa_mn       | <b>Pd_pa manual select</b><br>0x0: From FSM<br>0x1: from register                                          | RW  | 0x0   |
| 17:16       | Tia_lobias     | <b>Output to analogue</b>                                                                                  | RW  | 0x1   |
| 15          | Pd_adc_ldo_reg | <b>Pd_adc_ldo manual value</b>                                                                             | RW  | 0x0   |
| 14          | Pd_adc_ldo_mn  | <b>Pd_adc_ldo manual select</b><br>0x0: From FSM<br>0x1: from register                                     | RW  | 0x0   |
| 13          | Pd_mix_reg     | <b>Pd_mix manual value</b>                                                                                 | RW  | 0x0   |
| 12          | Pd_mix_mn      | <b>Pd_mix manual select</b><br>0x0: From FSM<br>0x1: from register                                         | RW  | 0x0   |
| 11:10       | Bm_filter      | <b>Filter bias current control</b>                                                                         | RW  | 0x1   |
| 9:8         | Bm_lna         | <b>Output to analogue</b>                                                                                  | RW  | 0x0   |
| 7           | Pa_voltage     | <b>Pa voltage output to analogue</b>                                                                       | RW  | 0x0   |
| 6           | Pd_xtal_reg    | <b>Pd_xtal manual value</b>                                                                                | RW  | 0x0   |
| 5           | Pd_xtal_mn     | <b>Pd_xtal manual select</b>                                                                               | RW  | 0x0   |
| 4:0         | Xtal_cc        | <b>Output to analogue</b>                                                                                  | RW  | 0x1F  |

## 19.4.40. TEST\_PKDET

Addr = 0x1F

| Bit(s) | Name            | Description                                                          | R/W | Reset |
|--------|-----------------|----------------------------------------------------------------------|-----|-------|
| 23     | test_en         | Test mode enable                                                     | RW  | 0x0   |
| 22:20  | reserved        | -                                                                    | RW  | 0x0   |
| 19:18  | miso_drv        | Output driving capability of MISO                                    | RW  | 0x1   |
| 17:16  | pll_icp_sel     | Charge pump current control                                          | RW  | 0x1   |
| 15:14  | test_mode       | Test mode select                                                     | RW  | 0x0   |
| 12:10  | test_point_sel1 | Test point select                                                    | RW  | 0x0   |
| 9:8    | test_point_sel0 | Test point select                                                    | RW  | 0x0   |
| 7:6    | xtal_resc       | Resistor value control of xtal bias                                  | RW  | 0x0   |
| 5      | bm_xtal         | Xtal bias current control                                            | RW  | 0x1   |
| 4      | Reserved        | -                                                                    | RW  | 0x0   |
| 3:2    | pll_vdiv2_sel   | Div2 dc bias control, pll_vdiv2_sel should be set 01 for normal work | RW  | 0x3   |
| 1      | pd_vco_pkdet_mn | Manual mode enable of pd_vco_pkdet                                   | RW  | 0x0   |
| 0      | pd_vco_pkdet_rg | Manual mode register of pd_vco_pkdet                                 | RW  | 0x0   |

## 19.5. 应用使用说明

### 19.5.1. 普通 2.4G 模式

#### 19.5.1.1. 2.4G 模式初始化配置流程

下面的截图是 SDK 中的初始化过程，请按照我们 SDK 给的初始化流程走， 初始化完成之后再根据您的需要进行其他的配置。要注意， DYNPD 寄存器的选择 SPI 线数的位， 不要在应用配置中改掉了，还有 FEATRUE 寄存器的 bit4， CONFIG 寄存器的 bit7 一定要注意置”1”。

```

/**
 * @brief RF initialization function
 * @param None
 * @retval None
 */
void rf_init(void)
{
    u8 wdata[5];

    rf_spi_write_byte(REG_BANK0_FEATURE, 0x20); // soft_reset
    rf_ce_low();
    rf_spi_write_byte(REG_BANK0_CONFIG, 0x8b); // power up
    delay_ms(3); // wait 3 ms
    rf_spi_write_byte(REG_BANK0_PMU_CTL, 0xa8); // HS6220_PWRDWN = 00
    delay_ms(2);
    rf_spi_write_byte(REG_BANK0_FEATURE, 0x10); // VCO_AMP_TX_MUX = b'0, A2 don't need config this bit
    rf_bank_switch(RF_BANK1);
    rf_spi_write_byte(REG_BANK1_TEST_PKDET, 0x24); // pll_vdiv2_sel = 01, A2 don't need config this bit
    rf_bank_switch(RF_BANK0);
    rf_ce_high();
    delay_ms(1);
    rf_ce_low(); // 一定要注意，校准的时候CE是低的
    while((rf_spi_read_byte(REG_BANK0_RF_SETUP) & 0x20) == 0x00); // wait cal done
    rf_spi_write_byte(REG_BANK0_RF_SETUP, 0x40); // cal_en = 0

    rf_bank_switch(RF_BANK1);
    wdata[2] = 0x75; // bp_dac = 1, bp_rc = 1
    wdata[1] = 0x98; // bp_vco_amp = 1, bp_vco_ldo = 1
    wdata[0] = 0x20;
    rf_spi_write_buf(REG_BANK1_CAL_CTRL, wdata, 3);

    wdata[2] = 0x05;
    wdata[1] = 0xa0;
    wdata[0] = 0x03;
    rf_spi_write_buf(REG_BANK1_FAGC_CTRL_1, wdata, 3); // increase fitler agc threshold start (A2 don't need config this bit)
    wdata[1] = 0xb2;
    wdata[0] = 0xcf; // increase fitler agc threshold
    rf_spi_write_buf(REG_BANK1_AGC_CTRL, wdata, 2); // increase fitler agc threshold end (A2 don't need config this bit)

    wdata[2] = 0x11;
    wdata[1] = 0x04;
    wdata[0] = 0x1f;
    rf_spi_write_buf(REG_BANK1_RF_IVGEN, wdata, 3); // xtal_cc = 0x1f (A2 don't need config this bit, can be 0x1f or 0x1e)

    rf_bank_switch(RF_BANK0);
    wdata[0] = 0x46;
    wdata[1] = 0x0b;
    wdata[2] = 0xaf;
    wdata[3] = 0x43;
    wdata[4] = 0x98;
    rf_spi_write_buf(REG_BANK0_RX_ADDR_P0, wdata, 5); // set rx address
    wdata[0]=0x46;
    wdata[1]=0x0b;
    wdata[2]=0xaf;
    wdata[3]=0x43;
    wdata[4]=0x98;
    rf_spi_write_buf(REG_BANK0_TX_ADDR, wdata, 5); // set tx address

    rf_clear_all_irq();
    rf_flush_tx();
    rf_flush_rx();
}

```

图-1 2.4G 模式初始化流程

- 1) 芯片上电等待 10ms, 然后进行软复位(Soft\_RST);

- 2) 在 bank0 的 DYNPD 寄存器中把 Bypass\_io 置 0, 关掉 IO 复用功能, 否则 MOSI 会有电平冲突;
- 3) bank0 的 CONFIG 寄存器中把 PWR\_UP 置 1, 打开晶振, 然后延时 3ms 让晶振启动;
- 4) bank0 的 PMU\_CTL 中把 RF\_PWRDWN 置 00, 让芯片进入工作模式, 延时 2ms, 让数字开电;
- 5) bank0 的 FEATURE 寄存器中把 vco\_amp\_tx\_mux 置 0;
- 6) bank1 的 TEST\_PKDET 中把 p11\_vdiv2\_sel 置 00;
- 7) 拉 CE pulse, CE pulse 宽度大于 40us, 然后在 bank0 的 RF\_SETUP 中查询 CAL\_DONE, CAL\_DONE=1 表示校准完成;
- 8) bank0 的 RF\_SETUP 中把 CAL\_EN 置 0;
- 9) bank1 的 CAL\_CTL 寄存器配置为 0x28 0x75 0x98 0x20(高字节在前);

### 19.5.1.2. 2.4G 模式常用配置寄存器

```

....rf_init();初始化rf, 注意初始化里面, CE已经是拉低的
....rf_spi_write_byte(REG_BANK0_FEATURE, 0x10);feature和dynamic寄存器根据应用配置, 且收发端要对应上, 否则收到的数据不对
....rf_spi_write_byte(REG_BANK0_EN_AA, 0x00);是否使能自动应答
....rf_spi_write_byte(REG_BANK0_CONFIG, 0xfa);注意config寄存器的最高位为1, 其他位根据需要配置
....rf_spi_write_byte(REG_BANK0_RX_PW_P0, 0x20);配置数据包长度, 1~32字节
....rf_spi_write_byte(REG_BANK0_RF_CH, 0x02);rf信道配置
....rf_spi_write_byte(REG_BANK0_EN_RXADDR, 0x03);固化配置
....rf_flush_tx();
....rf_flush_rx();
....rf_clear_all_irq();
....rf_ce_low();

```

图-2 2.4G 模式应用时寄存器配置

### 19.5.1.3. 2.4G 模式需要注意的一些事项

#### A. 软件复位

软件复位的寄存器是在 BANK0 的FEATURE 寄存器的 bit5 这个位。

#### 19.4.19. |FEATURE

Addr = 0x1D

| Bit(s) | Name           | Description                                                                             | R/W | Reset |
|--------|----------------|-----------------------------------------------------------------------------------------|-----|-------|
| 7      | Long_packet_en | Long packet mode enable                                                                 | RW  | 0x0   |
| 6      | Ble_en         | BLE mode enable                                                                         | RW  | 0x0   |
| 5      | Soft_rst       | Software reset                                                                          | RW  | 0x0   |
| 4      | BP_GAU         | Bypass Gaussian filter, BLE mode should not bypass Gaussian filter                      | RW  | 0x1   |
| 3      | Vco_amp_tx_mux | Vco_amp_tx_mux=0,<br>vco_amp_ctr[3:0] (VCO amplitude control bit) of RX and TX are both | RW  | 0x1   |

#### B. CONFIG 寄存器

芯片的 CONFIG 寄存器的最高位要置”1”，最高位不置”1”的话不能进行收发数据。

## 19.4.1. | CONFIG

Addr = 0x00

| Bit(s) | Name       | Description                                                                                                                                       | R/W | Reset |
|--------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7      | TX_GURD_EN | Bypass tx guard enable                                                                                                                            | RW  | 0x1   |
| 6      | MASK_RX_DR | <b>Mask interrupt caused by RX_DR</b><br>0x0: Reflect RX_DR as active low interrupt on the IRQ pin<br>0x1: Interrupt not reflected on the IRQ pin | RW  | 0x0   |
| 5      | MASK_TX_DS | <b>Mask interrupt caused by TX_DS</b><br>0x0: Reflect TX_DS as active low interrupt on the IRQ pin<br>0x1: Interrupt not reflected on the IRQ pin | RW  | 0x0   |
| 4      | MASK_MAX_R | <b>Mask interrupt caused by MAX_RT</b><br>0x0 : Reflect MAX_RT as active low interrupt on the IRQ pin                                             | W   | 0x0   |

## C. 数据白化功能

白化使能位是放在 BANK0 的EN\_RXADDR 的bit3 这个位。

## 19.4.3. | EN\_RXADDR

Addr = 0x02

| Bit(s) | Name        | Description                                              | R/W | Reset |
|--------|-------------|----------------------------------------------------------|-----|-------|
| 7:4    | Reserved    |                                                          | RW  | 0x0   |
| 3      | scramble_en | <b>Scramble enable</b><br>0x0: Disable<br>0x1: Enable    | RW  | 0x1   |
| 2      | ERX_P2      | <b>Enable data pipe 2</b><br>0x0: Disable<br>0x1: Enable | RW  | 0x0   |
| 1      | ERX_P1      | <b>Enable data pipe 1</b><br>0x0: Disable<br>0x1: Enable | RW  | 0x1   |

## D. FEATURE 寄存器

这个寄存器的话，在 2.4G 模式下，bit4 这个位是要置”1”的。低 3bit

根据实际使用配置，需要注意的是收发端的配置要有值。

#### 19. 4. 19. FEATURE |

Addr = 0x1D

| Bit(s) | Name           | Description                                                                                                                                                                                                                 | R/W | Reset |
|--------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7      | Long_packet_en | Long packet mode enable                                                                                                                                                                                                     | RW  | 0x0   |
| 6      | Ble_en         | BLE mode enable                                                                                                                                                                                                             | RW  | 0x0   |
| 5      | Soft_rst       | Software reset                                                                                                                                                                                                              | RW  | 0x0   |
| 4      | BP_GAU         | Bypass Gaussian filter, BLE mode should not bypass Gaussian filter                                                                                                                                                          | RW  | 0x1   |
| 3      | Vco_amp_tx_mux | Vco_amp_tx_mux=0, vco_amp_ctrl[3:0] (VCO amplitude control bit) of RX and TX are both from calibration fsm;<br>Vco_amp_tx_mux=1, vco_amp_ctrl[3:0] of RX is from calibration fsm, vco_amp_ctrl[3:0] of TX is fixed to 0x0c; | RW  | 0x1   |
| 2      | EN_DPL         | Enables Dynamic Payload Length                                                                                                                                                                                              | RW  | 0x0   |
| 1      | EN_ACK_PAY     | Enables Payload with ACK                                                                                                                                                                                                    | RW  | 0x0   |
| 0      | EN_DYN_ACK     | Enables the W_TX_PAYLOAD_NOACK command                                                                                                                                                                                      | RW  | 0x0   |

#### E. DYNPD 寄存器

这个寄存器低 3bit 是对应 3 个 pipe, 剩下的是其他功能 bit. 这里需要注意的是, TX8W7010 只支持 3 线 SPI 接口, 所以必须保证 bit3 要置”0”。

#### 19. 4. 18. DYNPD

Addr = 0x1C

| Bit(s) | Name          | Description                                                              | R/W | Reset |
|--------|---------------|--------------------------------------------------------------------------|-----|-------|
| 7      | Reg_output    | Register control IRQ output                                              | RW  | 0x0   |
| 6      | Reg_output_en | Register control IRQ output enable                                       | RW  | 0x0   |
| 5      | Bypass_io     | Bypass IRQ and MOSI, after HS6220 power up, Bypass_io should be set 0    | RW  | 0x1   |
| 4      | Xn_en         | Xn mode enable                                                           | RW  | 0x0   |
| 3      | Spi4_en       | 4-wire SPI enable                                                        | RW  | 0x0   |
| 2      | DPL_P2        | Enable dynamic payload length data pipe 2. (Requires EN_DPL and ENAA_P2) | RW  | 0x0   |
| 1      | DPL_P1        | Enable dynamic payload length data pipe 1. (Requires EN_DPL and ENAA_P1) | RW  | 0x0   |
| 0      | DPL_P0        | Enable dynamic payload length                                            | RW  | 0x0   |

#### F. 接收端防死机处理

在接收端的接收函数, 需要做下面的 2 个处理, 一个是 20~50ms 时间收不到数据, 要进行一次睡眠唤醒; 如果 300~500ms 的时间一次数据都收不到,

则要软件复位重新初始化一次。

#### G. 接收端接收处理数据的正确顺序

```
rf_clear_all_irq();
//CE拉高才能接收数据
rf_ce_high();

while(1) {
    //读取状态寄存器，看看是否有收到数据
    status = rf_spi_read_byte(REG_BANK0_STATUS);
    //如果有收到数据
    if((status & RF_STATUS_RX_DR) == 1) {
        //读取FIFO里面数据的长度
        rx_len = rf_receive_pack(rx_payload);
        if(rx_len == PAYLOAD_MAX_LEN) {
            //成功收到数据包
            success_cnt++;
            if(success_cnt > 250) {
                success_cnt = 0;
            }
        }
        //CE拉低
        rf_ce_low();
        //清状态寄存器标志
        rf_clear_all_irq();
        //清空rx_fifo
        rf_flush_rx();
        //CE拉高等待下次数据到来
        rf_ce_high();
    } else if(rx_len != 0) {
        rf_ce_low();
        rf_flush_rx();
        rf_clear_all_irq();
        rf_ce_high();
    }
}
```

要注意收到数据之后的正确操作  
CE先拉低  
清FIFO  
设置频点，设置地址等  
CE拉高进入接收状态

图-3 接收端操作流程

#### H. 发送端正确的发送数据操作

图-4 发送端操作流程